Wipe All

Edwin [2016-07-24 21:37:49]
Wipe All
Filename
.gitattributes
.gitignore
LICENSE.md
Pokemon Go Rocket API.sln
PokemonGo.RocketAPI.Console/App.config
PokemonGo.RocketAPI.Console/PokemonGo.RocketAPI.Console.csproj
PokemonGo.RocketAPI.Console/Program.cs
PokemonGo.RocketAPI.Console/Properties/AssemblyInfo.cs
PokemonGo.RocketAPI.Console/Properties/Resources.Designer.cs
PokemonGo.RocketAPI.Console/Properties/Resources.resx
PokemonGo.RocketAPI.Console/Settings.cs
PokemonGo.RocketAPI.Console/UserSettings.Designer.cs
PokemonGo.RocketAPI.Console/UserSettings.cs
PokemonGo.RocketAPI.Console/UserSettings.settings
PokemonGo.RocketAPI.Console/packages.config
PokemonGo.RocketAPI.Logic/Inventory.cs
PokemonGo.RocketAPI.Logic/Logic.cs
PokemonGo.RocketAPI.Logic/Navigation.cs
PokemonGo.RocketAPI.Logic/PokemonGo.RocketAPI.Logic.csproj
PokemonGo.RocketAPI.Logic/Properties/AssemblyInfo.cs
PokemonGo.RocketAPI.Logic/Utils/GPXReader.cs
PokemonGo.RocketAPI.Logic/Utils/LocationUtils.cs
PokemonGo.RocketAPI.Logic/Utils/Statistics.cs
PokemonGo.RocketAPI.Logic/Utils/StringUtils.cs
PokemonGo.RocketAPI.Logic/app.config
PokemonGo.RocketAPI/Client.cs
PokemonGo.RocketAPI/Enums/AuthType.cs
PokemonGo.RocketAPI/Enums/MiscEnums.cs
PokemonGo.RocketAPI/Enums/RequestType.cs
PokemonGo.RocketAPI/Exceptions/AccessTokenExpiredException.cs
PokemonGo.RocketAPI/Exceptions/AccountNotVerifiedException.cs
PokemonGo.RocketAPI/Exceptions/InvalidResponseException.cs
PokemonGo.RocketAPI/Exceptions/PTCOfflineException.cs
PokemonGo.RocketAPI/Extensions/DateTimeExtensions.cs
PokemonGo.RocketAPI/Extensions/HttpClientExtensions.cs
PokemonGo.RocketAPI/GeneratedCode/AllEnum.cs
PokemonGo.RocketAPI/GeneratedCode/Payloads.cs
PokemonGo.RocketAPI/GeneratedCode/Request.cs
PokemonGo.RocketAPI/GeneratedCode/Response.cs
PokemonGo.RocketAPI/Helpers/Git.cs
PokemonGo.RocketAPI/Helpers/HttpClientHelper.cs
PokemonGo.RocketAPI/Helpers/JsonHelper.cs
PokemonGo.RocketAPI/Helpers/ProtoHelper.cs
PokemonGo.RocketAPI/Helpers/RandomHelper.cs
PokemonGo.RocketAPI/Helpers/RequestBuilder.cs
PokemonGo.RocketAPI/Helpers/RetryHandler.cs
PokemonGo.RocketAPI/Helpers/S2Helper.cs
PokemonGo.RocketAPI/Helpers/Utils.cs
PokemonGo.RocketAPI/ISettings.cs
PokemonGo.RocketAPI/Logging/Logger.cs
PokemonGo.RocketAPI/Login/GoogleLogin.cs
PokemonGo.RocketAPI/Login/PtcLogin.cs
PokemonGo.RocketAPI/PokemonGo.RocketAPI.csproj
PokemonGo.RocketAPI/PokemonInfo.cs
PokemonGo.RocketAPI/Properties/AssemblyInfo.cs
PokemonGo.RocketAPI/Proto/AllEnum.proto
PokemonGo.RocketAPI/Proto/Payloads.proto
PokemonGo.RocketAPI/Proto/Request.proto
PokemonGo.RocketAPI/Proto/Response.proto
PokemonGo.RocketAPI/Resources.cs
PokemonGo.RocketAPI/app.config
PokemonGo.RocketAPI/packages.config
README.md
Screenshot.png
StatisticScreenshot.png
diff --git a/.gitattributes b/.gitattributes
deleted file mode 100644
index 1ff0c42..0000000
--- a/.gitattributes
+++ /dev/null
@@ -1,63 +0,0 @@
-###############################################################################
-# Set default behavior to automatically normalize line endings.
-###############################################################################
-* text=auto
-
-###############################################################################
-# Set default behavior for command prompt diff.
-#
-# This is need for earlier builds of msysgit that does not have it on by
-# default for csharp files.
-# Note: This is only used by command line
-###############################################################################
-#*.cs     diff=csharp
-
-###############################################################################
-# Set the merge driver for project and solution files
-#
-# Merging from the command prompt will add diff markers to the files if there
-# are conflicts (Merging from VS is not affected by the settings below, in VS
-# the diff markers are never inserted). Diff markers may cause the following
-# file extensions to fail to load in VS. An alternative would be to treat
-# these files as binary and thus will always conflict and require user
-# intervention with every merge. To do so, just uncomment the entries below
-###############################################################################
-#*.sln       merge=binary
-#*.csproj    merge=binary
-#*.vbproj    merge=binary
-#*.vcxproj   merge=binary
-#*.vcproj    merge=binary
-#*.dbproj    merge=binary
-#*.fsproj    merge=binary
-#*.lsproj    merge=binary
-#*.wixproj   merge=binary
-#*.modelproj merge=binary
-#*.sqlproj   merge=binary
-#*.wwaproj   merge=binary
-
-###############################################################################
-# behavior for image files
-#
-# image files are treated as binary by default.
-###############################################################################
-#*.jpg   binary
-#*.png   binary
-#*.gif   binary
-
-###############################################################################
-# diff behavior for common document formats
-#
-# Convert binary document formats to text before diffing them. This feature
-# is only available from the command line. Turn it on by uncommenting the
-# entries below.
-###############################################################################
-#*.doc   diff=astextplain
-#*.DOC   diff=astextplain
-#*.docx  diff=astextplain
-#*.DOCX  diff=astextplain
-#*.dot   diff=astextplain
-#*.DOT   diff=astextplain
-#*.pdf   diff=astextplain
-#*.PDF   diff=astextplain
-#*.rtf   diff=astextplain
-#*.RTF   diff=astextplain
diff --git a/.gitignore b/.gitignore
deleted file mode 100644
index 9da7242..0000000
--- a/.gitignore
+++ /dev/null
@@ -1,8 +0,0 @@
-################################################################################
-# This .gitignore file was automatically created by Microsoft(R) Visual Studio.
-################################################################################
-
-packages
-bin/
-obj/
-/PokemonGo/RocketAPI/Proto/google/protobuf
diff --git a/LICENSE.md b/LICENSE.md
deleted file mode 100644
index 9cecc1d..0000000
--- a/LICENSE.md
+++ /dev/null
@@ -1,674 +0,0 @@
-                    GNU GENERAL PUBLIC LICENSE
-                       Version 3, 29 June 2007
-
- Copyright (C) 2007 Free Software Foundation, Inc. <http://fsf.org/>
- Everyone is permitted to copy and distribute verbatim copies
- of this license document, but changing it is not allowed.
-
-                            Preamble
-
-  The GNU General Public License is a free, copyleft license for
-software and other kinds of works.
-
-  The licenses for most software and other practical works are designed
-to take away your freedom to share and change the works.  By contrast,
-the GNU General Public License is intended to guarantee your freedom to
-share and change all versions of a program--to make sure it remains free
-software for all its users.  We, the Free Software Foundation, use the
-GNU General Public License for most of our software; it applies also to
-any other work released this way by its authors.  You can apply it to
-your programs, too.
-
-  When we speak of free software, we are referring to freedom, not
-price.  Our General Public Licenses are designed to make sure that you
-have the freedom to distribute copies of free software (and charge for
-them if you wish), that you receive source code or can get it if you
-want it, that you can change the software or use pieces of it in new
-free programs, and that you know you can do these things.
-
-  To protect your rights, we need to prevent others from denying you
-these rights or asking you to surrender the rights.  Therefore, you have
-certain responsibilities if you distribute copies of the software, or if
-you modify it: responsibilities to respect the freedom of others.
-
-  For example, if you distribute copies of such a program, whether
-gratis or for a fee, you must pass on to the recipients the same
-freedoms that you received.  You must make sure that they, too, receive
-or can get the source code.  And you must show them these terms so they
-know their rights.
-
-  Developers that use the GNU GPL protect your rights with two steps:
-(1) assert copyright on the software, and (2) offer you this License
-giving you legal permission to copy, distribute and/or modify it.
-
-  For the developers' and authors' protection, the GPL clearly explains
-that there is no warranty for this free software.  For both users' and
-authors' sake, the GPL requires that modified versions be marked as
-changed, so that their problems will not be attributed erroneously to
-authors of previous versions.
-
-  Some devices are designed to deny users access to install or run
-modified versions of the software inside them, although the manufacturer
-can do so.  This is fundamentally incompatible with the aim of
-protecting users' freedom to change the software.  The systematic
-pattern of such abuse occurs in the area of products for individuals to
-use, which is precisely where it is most unacceptable.  Therefore, we
-have designed this version of the GPL to prohibit the practice for those
-products.  If such problems arise substantially in other domains, we
-stand ready to extend this provision to those domains in future versions
-of the GPL, as needed to protect the freedom of users.
-
-  Finally, every program is threatened constantly by software patents.
-States should not allow patents to restrict development and use of
-software on general-purpose computers, but in those that do, we wish to
-avoid the special danger that patents applied to a free program could
-make it effectively proprietary.  To prevent this, the GPL assures that
-patents cannot be used to render the program non-free.
-
-  The precise terms and conditions for copying, distribution and
-modification follow.
-
-                       TERMS AND CONDITIONS
-
-  0. Definitions.
-
-  "This License" refers to version 3 of the GNU General Public License.
-
-  "Copyright" also means copyright-like laws that apply to other kinds of
-works, such as semiconductor masks.
-
-  "The Program" refers to any copyrightable work licensed under this
-License.  Each licensee is addressed as "you".  "Licensees" and
-"recipients" may be individuals or organizations.
-
-  To "modify" a work means to copy from or adapt all or part of the work
-in a fashion requiring copyright permission, other than the making of an
-exact copy.  The resulting work is called a "modified version" of the
-earlier work or a work "based on" the earlier work.
-
-  A "covered work" means either the unmodified Program or a work based
-on the Program.
-
-  To "propagate" a work means to do anything with it that, without
-permission, would make you directly or secondarily liable for
-infringement under applicable copyright law, except executing it on a
-computer or modifying a private copy.  Propagation includes copying,
-distribution (with or without modification), making available to the
-public, and in some countries other activities as well.
-
-  To "convey" a work means any kind of propagation that enables other
-parties to make or receive copies.  Mere interaction with a user through
-a computer network, with no transfer of a copy, is not conveying.
-
-  An interactive user interface displays "Appropriate Legal Notices"
-to the extent that it includes a convenient and prominently visible
-feature that (1) displays an appropriate copyright notice, and (2)
-tells the user that there is no warranty for the work (except to the
-extent that warranties are provided), that licensees may convey the
-work under this License, and how to view a copy of this License.  If
-the interface presents a list of user commands or options, such as a
-menu, a prominent item in the list meets this criterion.
-
-  1. Source Code.
-
-  The "source code" for a work means the preferred form of the work
-for making modifications to it.  "Object code" means any non-source
-form of a work.
-
-  A "Standard Interface" means an interface that either is an official
-standard defined by a recognized standards body, or, in the case of
-interfaces specified for a particular programming language, one that
-is widely used among developers working in that language.
-
-  The "System Libraries" of an executable work include anything, other
-than the work as a whole, that (a) is included in the normal form of
-packaging a Major Component, but which is not part of that Major
-Component, and (b) serves only to enable use of the work with that
-Major Component, or to implement a Standard Interface for which an
-implementation is available to the public in source code form.  A
-"Major Component", in this context, means a major essential component
-(kernel, window system, and so on) of the specific operating system
-(if any) on which the executable work runs, or a compiler used to
-produce the work, or an object code interpreter used to run it.
-
-  The "Corresponding Source" for a work in object code form means all
-the source code needed to generate, install, and (for an executable
-work) run the object code and to modify the work, including scripts to
-control those activities.  However, it does not include the work's
-System Libraries, or general-purpose tools or generally available free
-programs which are used unmodified in performing those activities but
-which are not part of the work.  For example, Corresponding Source
-includes interface definition files associated with source files for
-the work, and the source code for shared libraries and dynamically
-linked subprograms that the work is specifically designed to require,
-such as by intimate data communication or control flow between those
-subprograms and other parts of the work.
-
-  The Corresponding Source need not include anything that users
-can regenerate automatically from other parts of the Corresponding
-Source.
-
-  The Corresponding Source for a work in source code form is that
-same work.
-
-  2. Basic Permissions.
-
-  All rights granted under this License are granted for the term of
-copyright on the Program, and are irrevocable provided the stated
-conditions are met.  This License explicitly affirms your unlimited
-permission to run the unmodified Program.  The output from running a
-covered work is covered by this License only if the output, given its
-content, constitutes a covered work.  This License acknowledges your
-rights of fair use or other equivalent, as provided by copyright law.
-
-  You may make, run and propagate covered works that you do not
-convey, without conditions so long as your license otherwise remains
-in force.  You may convey covered works to others for the sole purpose
-of having them make modifications exclusively for you, or provide you
-with facilities for running those works, provided that you comply with
-the terms of this License in conveying all material for which you do
-not control copyright.  Those thus making or running the covered works
-for you must do so exclusively on your behalf, under your direction
-and control, on terms that prohibit them from making any copies of
-your copyrighted material outside their relationship with you.
-
-  Conveying under any other circumstances is permitted solely under
-the conditions stated below.  Sublicensing is not allowed; section 10
-makes it unnecessary.
-
-  3. Protecting Users' Legal Rights From Anti-Circumvention Law.
-
-  No covered work shall be deemed part of an effective technological
-measure under any applicable law fulfilling obligations under article
-11 of the WIPO copyright treaty adopted on 20 December 1996, or
-similar laws prohibiting or restricting circumvention of such
-measures.
-
-  When you convey a covered work, you waive any legal power to forbid
-circumvention of technological measures to the extent such circumvention
-is effected by exercising rights under this License with respect to
-the covered work, and you disclaim any intention to limit operation or
-modification of the work as a means of enforcing, against the work's
-users, your or third parties' legal rights to forbid circumvention of
-technological measures.
-
-  4. Conveying Verbatim Copies.
-
-  You may convey verbatim copies of the Program's source code as you
-receive it, in any medium, provided that you conspicuously and
-appropriately publish on each copy an appropriate copyright notice;
-keep intact all notices stating that this License and any
-non-permissive terms added in accord with section 7 apply to the code;
-keep intact all notices of the absence of any warranty; and give all
-recipients a copy of this License along with the Program.
-
-  You may charge any price or no price for each copy that you convey,
-and you may offer support or warranty protection for a fee.
-
-  5. Conveying Modified Source Versions.
-
-  You may convey a work based on the Program, or the modifications to
-produce it from the Program, in the form of source code under the
-terms of section 4, provided that you also meet all of these conditions:
-
-    a) The work must carry prominent notices stating that you modified
-    it, and giving a relevant date.
-
-    b) The work must carry prominent notices stating that it is
-    released under this License and any conditions added under section
-    7.  This requirement modifies the requirement in section 4 to
-    "keep intact all notices".
-
-    c) You must license the entire work, as a whole, under this
-    License to anyone who comes into possession of a copy.  This
-    License will therefore apply, along with any applicable section 7
-    additional terms, to the whole of the work, and all its parts,
-    regardless of how they are packaged.  This License gives no
-    permission to license the work in any other way, but it does not
-    invalidate such permission if you have separately received it.
-
-    d) If the work has interactive user interfaces, each must display
-    Appropriate Legal Notices; however, if the Program has interactive
-    interfaces that do not display Appropriate Legal Notices, your
-    work need not make them do so.
-
-  A compilation of a covered work with other separate and independent
-works, which are not by their nature extensions of the covered work,
-and which are not combined with it such as to form a larger program,
-in or on a volume of a storage or distribution medium, is called an
-"aggregate" if the compilation and its resulting copyright are not
-used to limit the access or legal rights of the compilation's users
-beyond what the individual works permit.  Inclusion of a covered work
-in an aggregate does not cause this License to apply to the other
-parts of the aggregate.
-
-  6. Conveying Non-Source Forms.
-
-  You may convey a covered work in object code form under the terms
-of sections 4 and 5, provided that you also convey the
-machine-readable Corresponding Source under the terms of this License,
-in one of these ways:
-
-    a) Convey the object code in, or embodied in, a physical product
-    (including a physical distribution medium), accompanied by the
-    Corresponding Source fixed on a durable physical medium
-    customarily used for software interchange.
-
-    b) Convey the object code in, or embodied in, a physical product
-    (including a physical distribution medium), accompanied by a
-    written offer, valid for at least three years and valid for as
-    long as you offer spare parts or customer support for that product
-    model, to give anyone who possesses the object code either (1) a
-    copy of the Corresponding Source for all the software in the
-    product that is covered by this License, on a durable physical
-    medium customarily used for software interchange, for a price no
-    more than your reasonable cost of physically performing this
-    conveying of source, or (2) access to copy the
-    Corresponding Source from a network server at no charge.
-
-    c) Convey individual copies of the object code with a copy of the
-    written offer to provide the Corresponding Source.  This
-    alternative is allowed only occasionally and noncommercially, and
-    only if you received the object code with such an offer, in accord
-    with subsection 6b.
-
-    d) Convey the object code by offering access from a designated
-    place (gratis or for a charge), and offer equivalent access to the
-    Corresponding Source in the same way through the same place at no
-    further charge.  You need not require recipients to copy the
-    Corresponding Source along with the object code.  If the place to
-    copy the object code is a network server, the Corresponding Source
-    may be on a different server (operated by you or a third party)
-    that supports equivalent copying facilities, provided you maintain
-    clear directions next to the object code saying where to find the
-    Corresponding Source.  Regardless of what server hosts the
-    Corresponding Source, you remain obligated to ensure that it is
-    available for as long as needed to satisfy these requirements.
-
-    e) Convey the object code using peer-to-peer transmission, provided
-    you inform other peers where the object code and Corresponding
-    Source of the work are being offered to the general public at no
-    charge under subsection 6d.
-
-  A separable portion of the object code, whose source code is excluded
-from the Corresponding Source as a System Library, need not be
-included in conveying the object code work.
-
-  A "User Product" is either (1) a "consumer product", which means any
-tangible personal property which is normally used for personal, family,
-or household purposes, or (2) anything designed or sold for incorporation
-into a dwelling.  In determining whether a product is a consumer product,
-doubtful cases shall be resolved in favor of coverage.  For a particular
-product received by a particular user, "normally used" refers to a
-typical or common use of that class of product, regardless of the status
-of the particular user or of the way in which the particular user
-actually uses, or expects or is expected to use, the product.  A product
-is a consumer product regardless of whether the product has substantial
-commercial, industrial or non-consumer uses, unless such uses represent
-the only significant mode of use of the product.
-
-  "Installation Information" for a User Product means any methods,
-procedures, authorization keys, or other information required to install
-and execute modified versions of a covered work in that User Product from
-a modified version of its Corresponding Source.  The information must
-suffice to ensure that the continued functioning of the modified object
-code is in no case prevented or interfered with solely because
-modification has been made.
-
-  If you convey an object code work under this section in, or with, or
-specifically for use in, a User Product, and the conveying occurs as
-part of a transaction in which the right of possession and use of the
-User Product is transferred to the recipient in perpetuity or for a
-fixed term (regardless of how the transaction is characterized), the
-Corresponding Source conveyed under this section must be accompanied
-by the Installation Information.  But this requirement does not apply
-if neither you nor any third party retains the ability to install
-modified object code on the User Product (for example, the work has
-been installed in ROM).
-
-  The requirement to provide Installation Information does not include a
-requirement to continue to provide support service, warranty, or updates
-for a work that has been modified or installed by the recipient, or for
-the User Product in which it has been modified or installed.  Access to a
-network may be denied when the modification itself materially and
-adversely affects the operation of the network or violates the rules and
-protocols for communication across the network.
-
-  Corresponding Source conveyed, and Installation Information provided,
-in accord with this section must be in a format that is publicly
-documented (and with an implementation available to the public in
-source code form), and must require no special password or key for
-unpacking, reading or copying.
-
-  7. Additional Terms.
-
-  "Additional permissions" are terms that supplement the terms of this
-License by making exceptions from one or more of its conditions.
-Additional permissions that are applicable to the entire Program shall
-be treated as though they were included in this License, to the extent
-that they are valid under applicable law.  If additional permissions
-apply only to part of the Program, that part may be used separately
-under those permissions, but the entire Program remains governed by
-this License without regard to the additional permissions.
-
-  When you convey a copy of a covered work, you may at your option
-remove any additional permissions from that copy, or from any part of
-it.  (Additional permissions may be written to require their own
-removal in certain cases when you modify the work.)  You may place
-additional permissions on material, added by you to a covered work,
-for which you have or can give appropriate copyright permission.
-
-  Notwithstanding any other provision of this License, for material you
-add to a covered work, you may (if authorized by the copyright holders of
-that material) supplement the terms of this License with terms:
-
-    a) Disclaiming warranty or limiting liability differently from the
-    terms of sections 15 and 16 of this License; or
-
-    b) Requiring preservation of specified reasonable legal notices or
-    author attributions in that material or in the Appropriate Legal
-    Notices displayed by works containing it; or
-
-    c) Prohibiting misrepresentation of the origin of that material, or
-    requiring that modified versions of such material be marked in
-    reasonable ways as different from the original version; or
-
-    d) Limiting the use for publicity purposes of names of licensors or
-    authors of the material; or
-
-    e) Declining to grant rights under trademark law for use of some
-    trade names, trademarks, or service marks; or
-
-    f) Requiring indemnification of licensors and authors of that
-    material by anyone who conveys the material (or modified versions of
-    it) with contractual assumptions of liability to the recipient, for
-    any liability that these contractual assumptions directly impose on
-    those licensors and authors.
-
-  All other non-permissive additional terms are considered "further
-restrictions" within the meaning of section 10.  If the Program as you
-received it, or any part of it, contains a notice stating that it is
-governed by this License along with a term that is a further
-restriction, you may remove that term.  If a license document contains
-a further restriction but permits relicensing or conveying under this
-License, you may add to a covered work material governed by the terms
-of that license document, provided that the further restriction does
-not survive such relicensing or conveying.
-
-  If you add terms to a covered work in accord with this section, you
-must place, in the relevant source files, a statement of the
-additional terms that apply to those files, or a notice indicating
-where to find the applicable terms.
-
-  Additional terms, permissive or non-permissive, may be stated in the
-form of a separately written license, or stated as exceptions;
-the above requirements apply either way.
-
-  8. Termination.
-
-  You may not propagate or modify a covered work except as expressly
-provided under this License.  Any attempt otherwise to propagate or
-modify it is void, and will automatically terminate your rights under
-this License (including any patent licenses granted under the third
-paragraph of section 11).
-
-  However, if you cease all violation of this License, then your
-license from a particular copyright holder is reinstated (a)
-provisionally, unless and until the copyright holder explicitly and
-finally terminates your license, and (b) permanently, if the copyright
-holder fails to notify you of the violation by some reasonable means
-prior to 60 days after the cessation.
-
-  Moreover, your license from a particular copyright holder is
-reinstated permanently if the copyright holder notifies you of the
-violation by some reasonable means, this is the first time you have
-received notice of violation of this License (for any work) from that
-copyright holder, and you cure the violation prior to 30 days after
-your receipt of the notice.
-
-  Termination of your rights under this section does not terminate the
-licenses of parties who have received copies or rights from you under
-this License.  If your rights have been terminated and not permanently
-reinstated, you do not qualify to receive new licenses for the same
-material under section 10.
-
-  9. Acceptance Not Required for Having Copies.
-
-  You are not required to accept this License in order to receive or
-run a copy of the Program.  Ancillary propagation of a covered work
-occurring solely as a consequence of using peer-to-peer transmission
-to receive a copy likewise does not require acceptance.  However,
-nothing other than this License grants you permission to propagate or
-modify any covered work.  These actions infringe copyright if you do
-not accept this License.  Therefore, by modifying or propagating a
-covered work, you indicate your acceptance of this License to do so.
-
-  10. Automatic Licensing of Downstream Recipients.
-
-  Each time you convey a covered work, the recipient automatically
-receives a license from the original licensors, to run, modify and
-propagate that work, subject to this License.  You are not responsible
-for enforcing compliance by third parties with this License.
-
-  An "entity transaction" is a transaction transferring control of an
-organization, or substantially all assets of one, or subdividing an
-organization, or merging organizations.  If propagation of a covered
-work results from an entity transaction, each party to that
-transaction who receives a copy of the work also receives whatever
-licenses to the work the party's predecessor in interest had or could
-give under the previous paragraph, plus a right to possession of the
-Corresponding Source of the work from the predecessor in interest, if
-the predecessor has it or can get it with reasonable efforts.
-
-  You may not impose any further restrictions on the exercise of the
-rights granted or affirmed under this License.  For example, you may
-not impose a license fee, royalty, or other charge for exercise of
-rights granted under this License, and you may not initiate litigation
-(including a cross-claim or counterclaim in a lawsuit) alleging that
-any patent claim is infringed by making, using, selling, offering for
-sale, or importing the Program or any portion of it.
-
-  11. Patents.
-
-  A "contributor" is a copyright holder who authorizes use under this
-License of the Program or a work on which the Program is based.  The
-work thus licensed is called the contributor's "contributor version".
-
-  A contributor's "essential patent claims" are all patent claims
-owned or controlled by the contributor, whether already acquired or
-hereafter acquired, that would be infringed by some manner, permitted
-by this License, of making, using, or selling its contributor version,
-but do not include claims that would be infringed only as a
-consequence of further modification of the contributor version.  For
-purposes of this definition, "control" includes the right to grant
-patent sublicenses in a manner consistent with the requirements of
-this License.
-
-  Each contributor grants you a non-exclusive, worldwide, royalty-free
-patent license under the contributor's essential patent claims, to
-make, use, sell, offer for sale, import and otherwise run, modify and
-propagate the contents of its contributor version.
-
-  In the following three paragraphs, a "patent license" is any express
-agreement or commitment, however denominated, not to enforce a patent
-(such as an express permission to practice a patent or covenant not to
-sue for patent infringement).  To "grant" such a patent license to a
-party means to make such an agreement or commitment not to enforce a
-patent against the party.
-
-  If you convey a covered work, knowingly relying on a patent license,
-and the Corresponding Source of the work is not available for anyone
-to copy, free of charge and under the terms of this License, through a
-publicly available network server or other readily accessible means,
-then you must either (1) cause the Corresponding Source to be so
-available, or (2) arrange to deprive yourself of the benefit of the
-patent license for this particular work, or (3) arrange, in a manner
-consistent with the requirements of this License, to extend the patent
-license to downstream recipients.  "Knowingly relying" means you have
-actual knowledge that, but for the patent license, your conveying the
-covered work in a country, or your recipient's use of the covered work
-in a country, would infringe one or more identifiable patents in that
-country that you have reason to believe are valid.
-
-  If, pursuant to or in connection with a single transaction or
-arrangement, you convey, or propagate by procuring conveyance of, a
-covered work, and grant a patent license to some of the parties
-receiving the covered work authorizing them to use, propagate, modify
-or convey a specific copy of the covered work, then the patent license
-you grant is automatically extended to all recipients of the covered
-work and works based on it.
-
-  A patent license is "discriminatory" if it does not include within
-the scope of its coverage, prohibits the exercise of, or is
-conditioned on the non-exercise of one or more of the rights that are
-specifically granted under this License.  You may not convey a covered
-work if you are a party to an arrangement with a third party that is
-in the business of distributing software, under which you make payment
-to the third party based on the extent of your activity of conveying
-the work, and under which the third party grants, to any of the
-parties who would receive the covered work from you, a discriminatory
-patent license (a) in connection with copies of the covered work
-conveyed by you (or copies made from those copies), or (b) primarily
-for and in connection with specific products or compilations that
-contain the covered work, unless you entered into that arrangement,
-or that patent license was granted, prior to 28 March 2007.
-
-  Nothing in this License shall be construed as excluding or limiting
-any implied license or other defenses to infringement that may
-otherwise be available to you under applicable patent law.
-
-  12. No Surrender of Others' Freedom.
-
-  If conditions are imposed on you (whether by court order, agreement or
-otherwise) that contradict the conditions of this License, they do not
-excuse you from the conditions of this License.  If you cannot convey a
-covered work so as to satisfy simultaneously your obligations under this
-License and any other pertinent obligations, then as a consequence you may
-not convey it at all.  For example, if you agree to terms that obligate you
-to collect a royalty for further conveying from those to whom you convey
-the Program, the only way you could satisfy both those terms and this
-License would be to refrain entirely from conveying the Program.
-
-  13. Use with the GNU Affero General Public License.
-
-  Notwithstanding any other provision of this License, you have
-permission to link or combine any covered work with a work licensed
-under version 3 of the GNU Affero General Public License into a single
-combined work, and to convey the resulting work.  The terms of this
-License will continue to apply to the part which is the covered work,
-but the special requirements of the GNU Affero General Public License,
-section 13, concerning interaction through a network will apply to the
-combination as such.
-
-  14. Revised Versions of this License.
-
-  The Free Software Foundation may publish revised and/or new versions of
-the GNU General Public License from time to time.  Such new versions will
-be similar in spirit to the present version, but may differ in detail to
-address new problems or concerns.
-
-  Each version is given a distinguishing version number.  If the
-Program specifies that a certain numbered version of the GNU General
-Public License "or any later version" applies to it, you have the
-option of following the terms and conditions either of that numbered
-version or of any later version published by the Free Software
-Foundation.  If the Program does not specify a version number of the
-GNU General Public License, you may choose any version ever published
-by the Free Software Foundation.
-
-  If the Program specifies that a proxy can decide which future
-versions of the GNU General Public License can be used, that proxy's
-public statement of acceptance of a version permanently authorizes you
-to choose that version for the Program.
-
-  Later license versions may give you additional or different
-permissions.  However, no additional obligations are imposed on any
-author or copyright holder as a result of your choosing to follow a
-later version.
-
-  15. Disclaimer of Warranty.
-
-  THERE IS NO WARRANTY FOR THE PROGRAM, TO THE EXTENT PERMITTED BY
-APPLICABLE LAW.  EXCEPT WHEN OTHERWISE STATED IN WRITING THE COPYRIGHT
-HOLDERS AND/OR OTHER PARTIES PROVIDE THE PROGRAM "AS IS" WITHOUT WARRANTY
-OF ANY KIND, EITHER EXPRESSED OR IMPLIED, INCLUDING, BUT NOT LIMITED TO,
-THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR
-PURPOSE.  THE ENTIRE RISK AS TO THE QUALITY AND PERFORMANCE OF THE PROGRAM
-IS WITH YOU.  SHOULD THE PROGRAM PROVE DEFECTIVE, YOU ASSUME THE COST OF
-ALL NECESSARY SERVICING, REPAIR OR CORRECTION.
-
-  16. Limitation of Liability.
-
-  IN NO EVENT UNLESS REQUIRED BY APPLICABLE LAW OR AGREED TO IN WRITING
-WILL ANY COPYRIGHT HOLDER, OR ANY OTHER PARTY WHO MODIFIES AND/OR CONVEYS
-THE PROGRAM AS PERMITTED ABOVE, BE LIABLE TO YOU FOR DAMAGES, INCLUDING ANY
-GENERAL, SPECIAL, INCIDENTAL OR CONSEQUENTIAL DAMAGES ARISING OUT OF THE
-USE OR INABILITY TO USE THE PROGRAM (INCLUDING BUT NOT LIMITED TO LOSS OF
-DATA OR DATA BEING RENDERED INACCURATE OR LOSSES SUSTAINED BY YOU OR THIRD
-PARTIES OR A FAILURE OF THE PROGRAM TO OPERATE WITH ANY OTHER PROGRAMS),
-EVEN IF SUCH HOLDER OR OTHER PARTY HAS BEEN ADVISED OF THE POSSIBILITY OF
-SUCH DAMAGES.
-
-  17. Interpretation of Sections 15 and 16.
-
-  If the disclaimer of warranty and limitation of liability provided
-above cannot be given local legal effect according to their terms,
-reviewing courts shall apply local law that most closely approximates
-an absolute waiver of all civil liability in connection with the
-Program, unless a warranty or assumption of liability accompanies a
-copy of the Program in return for a fee.
-
-                     END OF TERMS AND CONDITIONS
-
-            How to Apply These Terms to Your New Programs
-
-  If you develop a new program, and you want it to be of the greatest
-possible use to the public, the best way to achieve this is to make it
-free software which everyone can redistribute and change under these terms.
-
-  To do so, attach the following notices to the program.  It is safest
-to attach them to the start of each source file to most effectively
-state the exclusion of warranty; and each file should have at least
-the "copyright" line and a pointer to where the full notice is found.
-
-    {one line to give the program's name and a brief idea of what it does.}
-    Copyright (C) {year}  {name of author}
-
-    This program is free software: you can redistribute it and/or modify
-    it under the terms of the GNU General Public License as published by
-    the Free Software Foundation, either version 3 of the License, or
-    (at your option) any later version.
-
-    This program 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.
-
-    You should have received a copy of the GNU General Public License
-    along with this program.  If not, see <http://www.gnu.org/licenses/>.
-
-Also add information on how to contact you by electronic and paper mail.
-
-  If the program does terminal interaction, make it output a short
-notice like this when it starts in an interactive mode:
-
-    {project}  Copyright (C) {year}  {fullname}
-    This program comes with ABSOLUTELY NO WARRANTY; for details type `show w'.
-    This is free software, and you are welcome to redistribute it
-    under certain conditions; type `show c' for details.
-
-The hypothetical commands `show w' and `show c' should show the appropriate
-parts of the General Public License.  Of course, your program's commands
-might be different; for a GUI interface, you would use an "about box".
-
-  You should also get your employer (if you work as a programmer) or school,
-if any, to sign a "copyright disclaimer" for the program, if necessary.
-For more information on this, and how to apply and follow the GNU GPL, see
-<http://www.gnu.org/licenses/>.
-
-  The GNU General Public License does not permit incorporating your program
-into proprietary programs.  If your program is a subroutine library, you
-may consider it more useful to permit linking proprietary applications with
-the library.  If this is what you want to do, use the GNU Lesser General
-Public License instead of this License.  But first, please read
-<http://www.gnu.org/philosophy/why-not-lgpl.html>.
diff --git a/Pokemon Go Rocket API.sln b/Pokemon Go Rocket API.sln
deleted file mode 100644
index 91f8a3f..0000000
--- a/Pokemon Go Rocket API.sln
+++ /dev/null
@@ -1,37 +0,0 @@
-
-Microsoft Visual Studio Solution File, Format Version 12.00
-# Visual Studio 14
-VisualStudioVersion = 14.0.23107.0
-MinimumVisualStudioVersion = 10.0.40219.1
-Project("{FAE04EC0-301F-11D3-BF4B-00C04F79EFBC}") = "PokemonGo.RocketAPI", "PokemonGo.RocketAPI\PokemonGo.RocketAPI.csproj", "{05D2DA44-1B8E-4CF7-94ED-4D52451CD095}"
-EndProject
-Project("{FAE04EC0-301F-11D3-BF4B-00C04F79EFBC}") = "PokemonGo.RocketAPI.Console", "PokemonGo.RocketAPI.Console\PokemonGo.RocketAPI.Console.csproj", "{1FEA147E-F704-497B-A538-00B053B5F672}"
-EndProject
-Project("{FAE04EC0-301F-11D3-BF4B-00C04F79EFBC}") = "PokemonGo.RocketAPI.Logic", "PokemonGo.RocketAPI.Logic\PokemonGo.RocketAPI.Logic.csproj", "{0739E40D-C589-4AEB-93E5-EE8CD6773C60}"
-EndProject
-Global
-	GlobalSection(SolutionConfigurationPlatforms) = preSolution
-		Debug|Any CPU = Debug|Any CPU
-		Release|Any CPU = Release|Any CPU
-	EndGlobalSection
-	GlobalSection(ProjectConfigurationPlatforms) = postSolution
-		{05D2DA44-1B8E-4CF7-94ED-4D52451CD095}.Debug|Any CPU.ActiveCfg = Debug|Any CPU
-		{05D2DA44-1B8E-4CF7-94ED-4D52451CD095}.Debug|Any CPU.Build.0 = Debug|Any CPU
-		{05D2DA44-1B8E-4CF7-94ED-4D52451CD095}.Release|Any CPU.ActiveCfg = Release|Any CPU
-		{05D2DA44-1B8E-4CF7-94ED-4D52451CD095}.Release|Any CPU.Build.0 = Release|Any CPU
-		{1FEA147E-F704-497B-A538-00B053B5F672}.Debug|Any CPU.ActiveCfg = Debug|Any CPU
-		{1FEA147E-F704-497B-A538-00B053B5F672}.Debug|Any CPU.Build.0 = Debug|Any CPU
-		{1FEA147E-F704-497B-A538-00B053B5F672}.Release|Any CPU.ActiveCfg = Release|Any CPU
-		{1FEA147E-F704-497B-A538-00B053B5F672}.Release|Any CPU.Build.0 = Release|Any CPU
-		{0739E40D-C589-4AEB-93E5-EE8CD6773C60}.Debug|Any CPU.ActiveCfg = Debug|Any CPU
-		{0739E40D-C589-4AEB-93E5-EE8CD6773C60}.Debug|Any CPU.Build.0 = Debug|Any CPU
-		{0739E40D-C589-4AEB-93E5-EE8CD6773C60}.Release|Any CPU.ActiveCfg = Release|Any CPU
-		{0739E40D-C589-4AEB-93E5-EE8CD6773C60}.Release|Any CPU.Build.0 = Release|Any CPU
-	EndGlobalSection
-	GlobalSection(SolutionProperties) = preSolution
-		HideSolutionNode = FALSE
-	EndGlobalSection
-	GlobalSection(ExtensibilityGlobals) = postSolution
-		EnterpriseLibraryConfigurationToolBinariesPathV6 = packages\EnterpriseLibrary.TransientFaultHandling.6.0.1304.0\lib\portable-net45+win+wp8;packages\EnterpriseLibrary.TransientFaultHandling.Data.6.0.1304.1\lib\NET45
-	EndGlobalSection
-EndGlobal
diff --git a/PokemonGo.RocketAPI.Console/App.config b/PokemonGo.RocketAPI.Console/App.config
deleted file mode 100644
index 33b0e91..0000000
--- a/PokemonGo.RocketAPI.Console/App.config
+++ /dev/null
@@ -1,75 +0,0 @@
-<?xml version="1.0" encoding="utf-8"?>
-<configuration>
-    <configSections>
-        <sectionGroup name="userSettings" type="System.Configuration.UserSettingsGroup, System, Version=4.0.0.0, Culture=neutral, PublicKeyToken=b77a5c561934e089" >
-            <section name="PokemonGo.RocketAPI.Console.UserSettings" type="System.Configuration.ClientSettingsSection, System, Version=4.0.0.0, Culture=neutral, PublicKeyToken=b77a5c561934e089" allowExeDefinition="MachineToLocalUser" requirePermission="false" />
-            <section name="PokemonGo.RocketAPI.Console.Settings" type="System.Configuration.ClientSettingsSection, System, Version=4.0.0.0, Culture=neutral, PublicKeyToken=b77a5c561934e089" allowExeDefinition="MachineToLocalUser" requirePermission="false" />
-        </sectionGroup>
-    </configSections>
-    <startup>
-        <supportedRuntime version="v4.0" sku=".NETFramework,Version=v4.5" />
-    </startup>
-  <runtime>
-    <assemblyBinding xmlns="urn:schemas-microsoft-com:asm.v1">
-      <dependentAssembly>
-        <assemblyIdentity name="Newtonsoft.Json" publicKeyToken="30ad4fe6b2a6aeed" culture="neutral" />
-        <bindingRedirect oldVersion="0.0.0.0-9.0.0.0" newVersion="9.0.0.0" />
-      </dependentAssembly>
-    </assemblyBinding>
-  </runtime>
-  <userSettings>
-    <PokemonGo.RocketAPI.Console.UserSettings>
-      <setting name="DefaultAltitude" serializeAs="String">
-        <value>10</value>
-      </setting>
-      <setting name="KeepMinIVPercentage" serializeAs="String">
-        <value>85</value>
-      </setting>
-      <setting name="KeepMinCP" serializeAs="String">
-        <value>1000</value>
-      </setting>
-      <setting name="WalkingSpeedInKilometerPerHour" serializeAs="String">
-        <value>250</value>
-      </setting>
-      <setting name="DefaultLatitude" serializeAs="String">
-        <value>0</value>
-      </setting>
-      <setting name="DefaultLongitude" serializeAs="String">
-        <value>0</value>
-      </setting>
-      <setting name="EvolveAllPokemonWithEnoughCandy" serializeAs="String">
-        <value>False</value>
-      </setting>
-      <setting name="TransferDuplicatePokemon" serializeAs="String">
-        <value>True</value>
-      </setting>
-      <setting name="UsePokemonToNotCatchFilter" serializeAs="String">
-        <value>False</value>
-      </setting>
-      <setting name="KeepMinDuplicatePokemon" serializeAs="String">
-        <value>2</value>
-      </setting>
-      <setting name="AuthType" serializeAs="String">
-        <value>Google</value>
-      </setting>
-      <setting name="PtcUsername" serializeAs="String">
-        <value>username</value>
-      </setting>
-      <setting name="PtcPassword" serializeAs="String">
-        <value>password</value>
-      </setting>
-      <setting name="PrioritizeIVOverCP" serializeAs="String">
-        <value>True</value>
-      </setting>
-      <setting name="MaxTravelDistanceInMeters" serializeAs="String">
-        <value>1000</value>
-      </setting>
-      <setting name="UseGPXPathing" serializeAs="String">
-        <value>False</value>
-      </setting>
-      <setting name="GPXFile" serializeAs="String">
-        <value>GPXFile.GPX</value>
-      </setting>
-    </PokemonGo.RocketAPI.Console.UserSettings>
-  </userSettings>
-</configuration>
\ No newline at end of file
diff --git a/PokemonGo.RocketAPI.Console/PokemonGo.RocketAPI.Console.csproj b/PokemonGo.RocketAPI.Console/PokemonGo.RocketAPI.Console.csproj
deleted file mode 100644
index 6896053..0000000
--- a/PokemonGo.RocketAPI.Console/PokemonGo.RocketAPI.Console.csproj
+++ /dev/null
@@ -1,106 +0,0 @@
-<?xml version="1.0" encoding="utf-8"?>
-<Project ToolsVersion="14.0" DefaultTargets="Build" xmlns="http://schemas.microsoft.com/developer/msbuild/2003">
-  <Import Project="$(MSBuildExtensionsPath)\$(MSBuildToolsVersion)\Microsoft.Common.props" Condition="Exists('$(MSBuildExtensionsPath)\$(MSBuildToolsVersion)\Microsoft.Common.props')" />
-  <PropertyGroup>
-    <Configuration Condition=" '$(Configuration)' == '' ">Debug</Configuration>
-    <Platform Condition=" '$(Platform)' == '' ">AnyCPU</Platform>
-    <ProjectGuid>{1FEA147E-F704-497B-A538-00B053B5F672}</ProjectGuid>
-    <OutputType>Exe</OutputType>
-    <AppDesignerFolder>Properties</AppDesignerFolder>
-    <RootNamespace>PokemonGo.RocketAPI.Console</RootNamespace>
-    <AssemblyName>PokemonGo.RocketAPI.Console</AssemblyName>
-    <TargetFrameworkVersion>v4.5</TargetFrameworkVersion>
-    <FileAlignment>512</FileAlignment>
-    <PrimaryVersionType>AssemblyVersionAttribute</PrimaryVersionType>
-    <AssemblyInfoFilePath>..\PokemonGo.RocketAPI\Properties\AssemblyInfo.cs</AssemblyInfoFilePath>
-    <UpdateAssemblyVersion>True</UpdateAssemblyVersion>
-    <UpdateAssemblyFileVersion>False</UpdateAssemblyFileVersion>
-    <UpdateAssemblyInfoVersion>False</UpdateAssemblyInfoVersion>
-    <AssemblyVersionSettings>YearStamp.MonthStamp.DayStamp.Increment</AssemblyVersionSettings>
-  </PropertyGroup>
-  <PropertyGroup Condition=" '$(Configuration)|$(Platform)' == 'Debug|AnyCPU' ">
-    <PlatformTarget>AnyCPU</PlatformTarget>
-    <DebugSymbols>true</DebugSymbols>
-    <DebugType>full</DebugType>
-    <Optimize>false</Optimize>
-    <OutputPath>bin\Debug\</OutputPath>
-    <DefineConstants>DEBUG;TRACE</DefineConstants>
-    <ErrorReport>prompt</ErrorReport>
-    <WarningLevel>4</WarningLevel>
-  </PropertyGroup>
-  <PropertyGroup Condition=" '$(Configuration)|$(Platform)' == 'Release|AnyCPU' ">
-    <PlatformTarget>AnyCPU</PlatformTarget>
-    <DebugType>pdbonly</DebugType>
-    <Optimize>true</Optimize>
-    <OutputPath>bin\Release\</OutputPath>
-    <DefineConstants>TRACE</DefineConstants>
-    <ErrorReport>prompt</ErrorReport>
-    <WarningLevel>4</WarningLevel>
-  </PropertyGroup>
-  <ItemGroup>
-    <Reference Include="Google.Protobuf, Version=3.0.0.0, Culture=neutral, PublicKeyToken=a7d26565bac4d604, processorArchitecture=MSIL">
-      <HintPath>..\packages\Google.Protobuf.3.0.0-beta3\lib\dotnet\Google.Protobuf.dll</HintPath>
-      <Private>True</Private>
-    </Reference>
-    <Reference Include="System" />
-    <Reference Include="System.Configuration" />
-    <Reference Include="System.Core" />
-    <Reference Include="System.Xml.Linq" />
-    <Reference Include="System.Data.DataSetExtensions" />
-    <Reference Include="Microsoft.CSharp" />
-    <Reference Include="System.Data" />
-    <Reference Include="System.Net.Http" />
-    <Reference Include="System.Xml" />
-  </ItemGroup>
-  <ItemGroup>
-    <Compile Include="Program.cs" />
-    <Compile Include="Properties\AssemblyInfo.cs" />
-    <Compile Include="Properties\Resources.Designer.cs">
-      <AutoGen>True</AutoGen>
-      <DesignTime>True</DesignTime>
-      <DependentUpon>Resources.resx</DependentUpon>
-    </Compile>
-    <Compile Include="Settings.cs" />
-    <Compile Include="UserSettings.cs" />
-    <Compile Include="UserSettings.Designer.cs">
-      <AutoGen>True</AutoGen>
-      <DesignTimeSharedInput>True</DesignTimeSharedInput>
-      <DependentUpon>UserSettings.settings</DependentUpon>
-    </Compile>
-  </ItemGroup>
-  <ItemGroup>
-    <None Include="App.config">
-      <SubType>Designer</SubType>
-    </None>
-    <None Include="packages.config" />
-    <None Include="UserSettings.settings">
-      <Generator>SettingsSingleFileGenerator</Generator>
-      <LastGenOutput>UserSettings.Designer.cs</LastGenOutput>
-    </None>
-  </ItemGroup>
-  <ItemGroup>
-    <ProjectReference Include="..\PokemonGo.RocketAPI.Logic\PokemonGo.RocketAPI.Logic.csproj">
-      <Project>{0739E40D-C589-4AEB-93E5-EE8CD6773C60}</Project>
-      <Name>PokemonGo.RocketAPI.Logic</Name>
-    </ProjectReference>
-    <ProjectReference Include="..\PokemonGo.RocketAPI\PokemonGo.RocketAPI.csproj">
-      <Project>{05D2DA44-1B8E-4CF7-94ED-4D52451CD095}</Project>
-      <Name>PokemonGo.RocketAPI</Name>
-    </ProjectReference>
-  </ItemGroup>
-  <ItemGroup>
-    <EmbeddedResource Include="Properties\Resources.resx">
-      <Generator>ResXFileCodeGenerator</Generator>
-      <LastGenOutput>Resources.Designer.cs</LastGenOutput>
-      <SubType>Designer</SubType>
-    </EmbeddedResource>
-  </ItemGroup>
-  <Import Project="$(MSBuildToolsPath)\Microsoft.CSharp.targets" />
-  <!-- To modify your build process, add your task inside one of the targets below and uncomment it.
-       Other similar extension points exist, see Microsoft.Common.targets.
-  <Target Name="BeforeBuild">
-  </Target>
-  <Target Name="AfterBuild">
-  </Target>
-  -->
-</Project>
\ No newline at end of file
diff --git a/PokemonGo.RocketAPI.Console/Program.cs b/PokemonGo.RocketAPI.Console/Program.cs
deleted file mode 100644
index bc62dcf..0000000
--- a/PokemonGo.RocketAPI.Console/Program.cs
+++ /dev/null
@@ -1,56 +0,0 @@
-#region
-
-using System;
-using System.Threading;
-using System.Threading.Tasks;
-using PokemonGo.RocketAPI.Exceptions;
-using PokemonGo.RocketAPI.Logging;
-
-#endregion
-
-
-namespace PokemonGo.RocketAPI.Console
-{
-    internal class Program
-    {
-
-        private static void Main(string[] args)
-        {
-            AppDomain.CurrentDomain.UnhandledException
-                += delegate (object sender, UnhandledExceptionEventArgs eargs)
-                {
-                    Exception exception = (Exception)eargs.ExceptionObject;
-                    System.Console.WriteLine("Unhandled exception: " + exception);
-                    Environment.Exit(1);
-                };
-
-            Logger.SetLogger();
-
-            Task.Run(() =>
-            {
-                try
-                {
-                    new Logic.Logic(new Settings()).Execute().Wait();
-                }
-                catch (PtcOfflineException)
-                {
-                    Logger.Write("PTC Servers are probably down OR your credentials are wrong. Try google", LogLevel.Error);
-                    Logger.Write("Trying again in 60 seconds...");
-                    Thread.Sleep(60000);
-                    new Logic.Logic(new Settings()).Execute().Wait();
-                }
-                catch (AccountNotVerifiedException)
-                {
-                    Logger.Write("Account not verified. - Exiting");
-                    Environment.Exit(0);
-                }
-                catch (Exception ex)
-                {
-                    Logger.Write($"Unhandled exception: {ex}", LogLevel.Error);
-                    new Logic.Logic(new Settings()).Execute().Wait();
-                }
-            });
-             System.Console.ReadLine();
-        }
-    }
-}
\ No newline at end of file
diff --git a/PokemonGo.RocketAPI.Console/Properties/AssemblyInfo.cs b/PokemonGo.RocketAPI.Console/Properties/AssemblyInfo.cs
deleted file mode 100644
index fd11297..0000000
--- a/PokemonGo.RocketAPI.Console/Properties/AssemblyInfo.cs
+++ /dev/null
@@ -1,36 +0,0 @@
-using System.Reflection;
-using System.Runtime.CompilerServices;
-using System.Runtime.InteropServices;
-
-// General Information about an assembly is controlled through the following
-// set of attributes. Change these attribute values to modify the information
-// associated with an assembly.
-[assembly: AssemblyTitle("PokemonGoRocketAPI.Console")]
-[assembly: AssemblyDescription("")]
-[assembly: AssemblyConfiguration("")]
-[assembly: AssemblyCompany("")]
-[assembly: AssemblyProduct("PokemonGoRocketAPI.Console")]
-[assembly: AssemblyCopyright("Copyright ©  2016")]
-[assembly: AssemblyTrademark("")]
-[assembly: AssemblyCulture("")]
-
-// Setting ComVisible to false makes the types in this assembly not visible
-// to COM components.  If you need to access a type in this assembly from
-// COM, set the ComVisible attribute to true on that type.
-[assembly: ComVisible(false)]
-
-// The following GUID is for the ID of the typelib if this project is exposed to COM
-[assembly: Guid("1fea147e-f704-497b-a538-00b053b5f672")]
-
-// Version information for an assembly consists of the following four values:
-//
-//      Major Version
-//      Minor Version
-//      Build Number
-//      Revision
-//
-// You can specify all the values or you can default the Build and Revision Numbers
-// by using the '*' as shown below:
-// [assembly: AssemblyVersion("1.0.*")]
-[assembly: AssemblyVersion("2016.7.22.5")]
-[assembly: AssemblyFileVersion("1.0.0.0")]
diff --git a/PokemonGo.RocketAPI.Console/Properties/Resources.Designer.cs b/PokemonGo.RocketAPI.Console/Properties/Resources.Designer.cs
deleted file mode 100644
index 1aa73bd..0000000
--- a/PokemonGo.RocketAPI.Console/Properties/Resources.Designer.cs
+++ /dev/null
@@ -1,63 +0,0 @@
-//------------------------------------------------------------------------------
-// <auto-generated>
-//     Dieser Code wurde von einem Tool generiert.
-//     Laufzeitversion:4.0.30319.42000
-//
-//     Änderungen an dieser Datei können falsches Verhalten verursachen und gehen verloren, wenn
-//     der Code erneut generiert wird.
-// </auto-generated>
-//------------------------------------------------------------------------------
-
-namespace PokemonGo.RocketAPI.Console.Properties {
-    using System;
-
-
-    /// <summary>
-    ///   Eine stark typisierte Ressourcenklasse zum Suchen von lokalisierten Zeichenfolgen usw.
-    /// </summary>
-    // Diese Klasse wurde von der StronglyTypedResourceBuilder automatisch generiert
-    // -Klasse über ein Tool wie ResGen oder Visual Studio automatisch generiert.
-    // Um einen Member hinzuzufügen oder zu entfernen, bearbeiten Sie die .ResX-Datei und führen dann ResGen
-    // mit der /str-Option erneut aus, oder Sie erstellen Ihr VS-Projekt neu.
-    [global::System.CodeDom.Compiler.GeneratedCodeAttribute("System.Resources.Tools.StronglyTypedResourceBuilder", "4.0.0.0")]
-    [global::System.Diagnostics.DebuggerNonUserCodeAttribute()]
-    [global::System.Runtime.CompilerServices.CompilerGeneratedAttribute()]
-    internal class Resources {
-
-        private static global::System.Resources.ResourceManager resourceMan;
-
-        private static global::System.Globalization.CultureInfo resourceCulture;
-
-        [global::System.Diagnostics.CodeAnalysis.SuppressMessageAttribute("Microsoft.Performance", "CA1811:AvoidUncalledPrivateCode")]
-        internal Resources() {
-        }
-
-        /// <summary>
-        ///   Gibt die zwischengespeicherte ResourceManager-Instanz zurück, die von dieser Klasse verwendet wird.
-        /// </summary>
-        [global::System.ComponentModel.EditorBrowsableAttribute(global::System.ComponentModel.EditorBrowsableState.Advanced)]
-        internal static global::System.Resources.ResourceManager ResourceManager {
-            get {
-                if (object.ReferenceEquals(resourceMan, null)) {
-                    global::System.Resources.ResourceManager temp = new global::System.Resources.ResourceManager("PokemonGo.RocketAPI.Console.Properties.Resources", typeof(Resources).Assembly);
-                    resourceMan = temp;
-                }
-                return resourceMan;
-            }
-        }
-
-        /// <summary>
-        ///   ÃÂœberschreibt die CurrentUICulture-Eigenschaft des aktuellen Threads für alle
-        ///   Ressourcenzuordnungen, die diese stark typisierte Ressourcenklasse verwenden.
-        /// </summary>
-        [global::System.ComponentModel.EditorBrowsableAttribute(global::System.ComponentModel.EditorBrowsableState.Advanced)]
-        internal static global::System.Globalization.CultureInfo Culture {
-            get {
-                return resourceCulture;
-            }
-            set {
-                resourceCulture = value;
-            }
-        }
-    }
-}
diff --git a/PokemonGo.RocketAPI.Console/Properties/Resources.resx b/PokemonGo.RocketAPI.Console/Properties/Resources.resx
deleted file mode 100644
index 1af7de1..0000000
--- a/PokemonGo.RocketAPI.Console/Properties/Resources.resx
+++ /dev/null
@@ -1,120 +0,0 @@
-<?xml version="1.0" encoding="utf-8"?>
-<root>
-  <!--
-    Microsoft ResX Schema
-
-    Version 2.0
-
-    The primary goals of this format is to allow a simple XML format
-    that is mostly human readable. The generation and parsing of the
-    various data types are done through the TypeConverter classes
-    associated with the data types.
-
-    Example:
-
-    ... ado.net/XML headers & schema ...
-    <resheader name="resmimetype">text/microsoft-resx</resheader>
-    <resheader name="version">2.0</resheader>
-    <resheader name="reader">System.Resources.ResXResourceReader, System.Windows.Forms, ...</resheader>
-    <resheader name="writer">System.Resources.ResXResourceWriter, System.Windows.Forms, ...</resheader>
-    <data name="Name1"><value>this is my long string</value><comment>this is a comment</comment></data>
-    <data name="Color1" type="System.Drawing.Color, System.Drawing">Blue</data>
-    <data name="Bitmap1" mimetype="application/x-microsoft.net.object.binary.base64">
-        <value>[base64 mime encoded serialized .NET Framework object]</value>
-    </data>
-    <data name="Icon1" type="System.Drawing.Icon, System.Drawing" mimetype="application/x-microsoft.net.object.bytearray.base64">
-        <value>[base64 mime encoded string representing a byte array form of the .NET Framework object]</value>
-        <comment>This is a comment</comment>
-    </data>
-
-    There are any number of "resheader" rows that contain simple
-    name/value pairs.
-
-    Each data row contains a name, and value. The row also contains a
-    type or mimetype. Type corresponds to a .NET class that support
-    text/value conversion through the TypeConverter architecture.
-    Classes that don't support this are serialized and stored with the
-    mimetype set.
-
-    The mimetype is used for serialized objects, and tells the
-    ResXResourceReader how to depersist the object. This is currently not
-    extensible. For a given mimetype the value must be set accordingly:
-
-    Note - application/x-microsoft.net.object.binary.base64 is the format
-    that the ResXResourceWriter will generate, however the reader can
-    read any of the formats listed below.
-
-    mimetype: application/x-microsoft.net.object.binary.base64
-    value   : The object must be serialized with
-            : System.Runtime.Serialization.Formatters.Binary.BinaryFormatter
-            : and then encoded with base64 encoding.
-
-    mimetype: application/x-microsoft.net.object.soap.base64
-    value   : The object must be serialized with
-            : System.Runtime.Serialization.Formatters.Soap.SoapFormatter
-            : and then encoded with base64 encoding.
-
-    mimetype: application/x-microsoft.net.object.bytearray.base64
-    value   : The object must be serialized into a byte array
-            : using a System.ComponentModel.TypeConverter
-            : and then encoded with base64 encoding.
-    -->
-  <xsd:schema id="root" xmlns="" xmlns:xsd="http://www.w3.org/2001/XMLSchema" xmlns:msdata="urn:schemas-microsoft-com:xml-msdata">
-    <xsd:import namespace="http://www.w3.org/XML/1998/namespace" />
-    <xsd:element name="root" msdata:IsDataSet="true">
-      <xsd:complexType>
-        <xsd:choice maxOccurs="unbounded">
-          <xsd:element name="metadata">
-            <xsd:complexType>
-              <xsd:sequence>
-                <xsd:element name="value" type="xsd:string" minOccurs="0" />
-              </xsd:sequence>
-              <xsd:attribute name="name" use="required" type="xsd:string" />
-              <xsd:attribute name="type" type="xsd:string" />
-              <xsd:attribute name="mimetype" type="xsd:string" />
-              <xsd:attribute ref="xml:space" />
-            </xsd:complexType>
-          </xsd:element>
-          <xsd:element name="assembly">
-            <xsd:complexType>
-              <xsd:attribute name="alias" type="xsd:string" />
-              <xsd:attribute name="name" type="xsd:string" />
-            </xsd:complexType>
-          </xsd:element>
-          <xsd:element name="data">
-            <xsd:complexType>
-              <xsd:sequence>
-                <xsd:element name="value" type="xsd:string" minOccurs="0" msdata:Ordinal="1" />
-                <xsd:element name="comment" type="xsd:string" minOccurs="0" msdata:Ordinal="2" />
-              </xsd:sequence>
-              <xsd:attribute name="name" type="xsd:string" use="required" msdata:Ordinal="1" />
-              <xsd:attribute name="type" type="xsd:string" msdata:Ordinal="3" />
-              <xsd:attribute name="mimetype" type="xsd:string" msdata:Ordinal="4" />
-              <xsd:attribute ref="xml:space" />
-            </xsd:complexType>
-          </xsd:element>
-          <xsd:element name="resheader">
-            <xsd:complexType>
-              <xsd:sequence>
-                <xsd:element name="value" type="xsd:string" minOccurs="0" msdata:Ordinal="1" />
-              </xsd:sequence>
-              <xsd:attribute name="name" type="xsd:string" use="required" />
-            </xsd:complexType>
-          </xsd:element>
-        </xsd:choice>
-      </xsd:complexType>
-    </xsd:element>
-  </xsd:schema>
-  <resheader name="resmimetype">
-    <value>text/microsoft-resx</value>
-  </resheader>
-  <resheader name="version">
-    <value>2.0</value>
-  </resheader>
-  <resheader name="reader">
-    <value>System.Resources.ResXResourceReader, System.Windows.Forms, Version=4.0.0.0, Culture=neutral, PublicKeyToken=b77a5c561934e089</value>
-  </resheader>
-  <resheader name="writer">
-    <value>System.Resources.ResXResourceWriter, System.Windows.Forms, Version=4.0.0.0, Culture=neutral, PublicKeyToken=b77a5c561934e089</value>
-  </resheader>
-</root>
\ No newline at end of file
diff --git a/PokemonGo.RocketAPI.Console/Settings.cs b/PokemonGo.RocketAPI.Console/Settings.cs
deleted file mode 100644
index 83176f3..0000000
--- a/PokemonGo.RocketAPI.Console/Settings.cs
+++ /dev/null
@@ -1,167 +0,0 @@
-#region
-
-using System;
-using System.Collections.Generic;
-using System.IO;
-using PokemonGo.RocketAPI.Enums;
-using PokemonGo.RocketAPI.GeneratedCode;
-using PokemonGo.RocketAPI.Logging;
-using System.Text.RegularExpressions;
-
-#endregion
-
-
-namespace PokemonGo.RocketAPI.Console
-{
-    public class Settings : ISettings
-    {
-        public AuthType AuthType => (AuthType)Enum.Parse(typeof(AuthType), UserSettings.Default.AuthType, true);
-        public string PtcUsername => UserSettings.Default.PtcUsername;
-        public string PtcPassword => UserSettings.Default.PtcPassword;
-        public double DefaultLatitude => UserSettings.Default.DefaultLatitude;
-        public double DefaultLongitude => UserSettings.Default.DefaultLongitude;
-        public double DefaultAltitude => UserSettings.Default.DefaultAltitude;
-
-        public float KeepMinIVPercentage => UserSettings.Default.KeepMinIVPercentage;
-        public int KeepMinCP => UserSettings.Default.KeepMinCP;
-        public double WalkingSpeedInKilometerPerHour => UserSettings.Default.WalkingSpeedInKilometerPerHour;
-        public bool EvolveAllPokemonWithEnoughCandy => UserSettings.Default.EvolveAllPokemonWithEnoughCandy;
-        public bool TransferDuplicatePokemon => UserSettings.Default.TransferDuplicatePokemon;
-        public bool UsePokemonToNotCatchFilter => UserSettings.Default.UsePokemonToNotCatchFilter;
-        public int KeepMinDuplicatePokemon => UserSettings.Default.KeepMinDuplicatePokemon;
-        public bool PrioritizeIVOverCP => UserSettings.Default.PrioritizeIVOverCP;
-        public int MaxTravelDistanceInMeters => UserSettings.Default.MaxTravelDistanceInMeters;
-
-        public bool UseGPXPathing => UserSettings.Default.UseGPXPathing;
-        public string GPXFile => UserSettings.Default.GPXFile;
-
-        private ICollection<PokemonId> _pokemonsToEvolve;
-        private ICollection<PokemonId> _pokemonsNotToTransfer;
-        private ICollection<PokemonId> _pokemonsNotToCatch;
-
-        public ICollection<KeyValuePair<ItemId, int>> ItemRecycleFilter => new[]
-        {
-            new KeyValuePair<ItemId, int>(ItemId.ItemUnknown, 0),
-            new KeyValuePair<ItemId, int>(ItemId.ItemPokeBall, 20),
-            new KeyValuePair<ItemId, int>(ItemId.ItemGreatBall, 20),
-            new KeyValuePair<ItemId, int>(ItemId.ItemUltraBall, 50),
-            new KeyValuePair<ItemId, int>(ItemId.ItemMasterBall, 100),
-
-            new KeyValuePair<ItemId, int>(ItemId.ItemPotion, 0),
-            new KeyValuePair<ItemId, int>(ItemId.ItemSuperPotion, 0),
-            new KeyValuePair<ItemId, int>(ItemId.ItemHyperPotion, 20),
-            new KeyValuePair<ItemId, int>(ItemId.ItemMaxPotion, 50),
-
-            new KeyValuePair<ItemId, int>(ItemId.ItemRevive, 10),
-            new KeyValuePair<ItemId, int>(ItemId.ItemMaxRevive, 50),
-
-            new KeyValuePair<ItemId, int>(ItemId.ItemLuckyEgg, 200),
-
-            new KeyValuePair<ItemId, int>(ItemId.ItemIncenseOrdinary, 100),
-            new KeyValuePair<ItemId, int>(ItemId.ItemIncenseSpicy, 100),
-            new KeyValuePair<ItemId, int>(ItemId.ItemIncenseCool, 100),
-            new KeyValuePair<ItemId, int>(ItemId.ItemIncenseFloral, 100),
-
-            new KeyValuePair<ItemId, int>(ItemId.ItemTroyDisk, 100),
-            new KeyValuePair<ItemId, int>(ItemId.ItemXAttack, 100),
-            new KeyValuePair<ItemId, int>(ItemId.ItemXDefense, 100),
-            new KeyValuePair<ItemId, int>(ItemId.ItemXMiracle, 100),
-
-            new KeyValuePair<ItemId, int>(ItemId.ItemRazzBerry, 20),
-            new KeyValuePair<ItemId, int>(ItemId.ItemBlukBerry, 10),
-            new KeyValuePair<ItemId, int>(ItemId.ItemNanabBerry, 10),
-            new KeyValuePair<ItemId, int>(ItemId.ItemWeparBerry, 30),
-            new KeyValuePair<ItemId, int>(ItemId.ItemPinapBerry, 30),
-
-            new KeyValuePair<ItemId, int>(ItemId.ItemSpecialCamera, 100),
-            new KeyValuePair<ItemId, int>(ItemId.ItemIncubatorBasicUnlimited, 100),
-            new KeyValuePair<ItemId, int>(ItemId.ItemIncubatorBasic, 100),
-            new KeyValuePair<ItemId, int>(ItemId.ItemPokemonStorageUpgrade, 100),
-            new KeyValuePair<ItemId, int>(ItemId.ItemItemStorageUpgrade, 100),
-        };
-
-        public ICollection<PokemonId> PokemonsToEvolve
-        {
-            get
-            {
-                //Type of pokemons to evolve
-                var defaultText = new string[] { "Zubat", "Pidgey", "Rattata" };
-                _pokemonsToEvolve = _pokemonsToEvolve ?? LoadPokemonList("PokemonsToEvolve", defaultText);
-                return _pokemonsToEvolve;
-            }
-        }
-
-        public ICollection<PokemonId> PokemonsNotToTransfer
-        {
-            get
-            {
-                //Type of pokemons not to transfer
-                var defaultText = new string[] { "Dragonite", "Charizard", "Zapdos", "Snorlax", "Alakazam", "Mew", "Mewtwo" };
-                _pokemonsNotToTransfer = _pokemonsNotToTransfer ?? LoadPokemonList("PokemonsNotToTransfer", defaultText);
-                return _pokemonsNotToTransfer;
-            }
-        }
-
-        public ICollection<PokemonId> PokemonsNotToCatch
-        {
-            get
-            {
-                //Type of pokemons not to catch
-                var defaultText = new string[] { "Zubat", "Pidgey", "Rattata" };
-                _pokemonsNotToCatch = _pokemonsNotToCatch ?? LoadPokemonList("PokemonsNotToCatch", defaultText);
-                return _pokemonsNotToCatch;
-            }
-        }
-
-        private ICollection<PokemonId> LoadPokemonList(string filename, string[] defaultContent)
-        {
-            ICollection<PokemonId> result = new List<PokemonId>();
-            Func<string, ICollection<PokemonId>> addPokemonToResult = delegate (string pokemonName) {
-                PokemonId pokemon;
-                if (Enum.TryParse<PokemonId>(pokemonName, out pokemon))
-                {
-                    result.Add((PokemonId)pokemon);
-                }
-                return result;
-            };
-
-            string path = Directory.GetCurrentDirectory() + "\\Configs\\";
-            if (!Directory.Exists(path))
-            {
-                DirectoryInfo di = Directory.CreateDirectory(path);
-            }
-            if (!File.Exists(path + filename + ".txt"))
-            {
-                Logger.Write($"File: \"\\Configs\\{filename}.txt\" not found, creating new...", LogLevel.Warning);
-                using (var w = File.AppendText(path + filename + ".txt"))
-                {
-                    Array.ForEach(defaultContent, x => w.WriteLine(x));
-                    Array.ForEach(defaultContent, x => addPokemonToResult(x));
-                    w.Close();
-                }
-            }
-            if (File.Exists(path + filename + ".txt"))
-            {
-                Logger.Write($"Loading File: \"\\Configs\\{filename}.txt\"", LogLevel.Info);
-
-                var content = string.Empty;
-                using (StreamReader reader = new StreamReader(path + filename + ".txt"))
-                {
-                    content = reader.ReadToEnd();
-                    reader.Close();
-                }
-                content = Regex.Replace(content, @"\\/\*(.|\n)*?\*\/", ""); //todo: supposed to remove comment blocks
-
-                StringReader tr = new StringReader(content);
-
-                var pokemonName = tr.ReadLine();
-                while (pokemonName != null)
-                {
-                    addPokemonToResult(pokemonName);
-                    pokemonName = tr.ReadLine();
-                }
-            }
-            return result;
-        }
-    }
-}
diff --git a/PokemonGo.RocketAPI.Console/UserSettings.Designer.cs b/PokemonGo.RocketAPI.Console/UserSettings.Designer.cs
deleted file mode 100644
index b20f503..0000000
--- a/PokemonGo.RocketAPI.Console/UserSettings.Designer.cs
+++ /dev/null
@@ -1,230 +0,0 @@
-//------------------------------------------------------------------------------
-// <auto-generated>
-//     Dieser Code wurde von einem Tool generiert.
-//     Laufzeitversion:4.0.30319.42000
-//
-//     Änderungen an dieser Datei können falsches Verhalten verursachen und gehen verloren, wenn
-//     der Code erneut generiert wird.
-// </auto-generated>
-//------------------------------------------------------------------------------
-
-namespace PokemonGo.RocketAPI.Console {
-
-
-    [global::System.Runtime.CompilerServices.CompilerGeneratedAttribute()]
-    [global::System.CodeDom.Compiler.GeneratedCodeAttribute("Microsoft.VisualStudio.Editors.SettingsDesigner.SettingsSingleFileGenerator", "14.0.0.0")]
-    internal sealed partial class UserSettings : global::System.Configuration.ApplicationSettingsBase {
-
-        private static UserSettings defaultInstance = ((UserSettings)(global::System.Configuration.ApplicationSettingsBase.Synchronized(new UserSettings())));
-
-        public static UserSettings Default {
-            get {
-                return defaultInstance;
-            }
-        }
-
-        [global::System.Configuration.UserScopedSettingAttribute()]
-        [global::System.Diagnostics.DebuggerNonUserCodeAttribute()]
-        [global::System.Configuration.DefaultSettingValueAttribute("10")]
-        public double DefaultAltitude {
-            get {
-                return ((double)(this["DefaultAltitude"]));
-            }
-            set {
-                this["DefaultAltitude"] = value;
-            }
-        }
-
-        [global::System.Configuration.UserScopedSettingAttribute()]
-        [global::System.Diagnostics.DebuggerNonUserCodeAttribute()]
-        [global::System.Configuration.DefaultSettingValueAttribute("85")]
-        public float KeepMinIVPercentage {
-            get {
-                return ((float)(this["KeepMinIVPercentage"]));
-            }
-            set {
-                this["KeepMinIVPercentage"] = value;
-            }
-        }
-
-        [global::System.Configuration.UserScopedSettingAttribute()]
-        [global::System.Diagnostics.DebuggerNonUserCodeAttribute()]
-        [global::System.Configuration.DefaultSettingValueAttribute("1000")]
-        public int KeepMinCP {
-            get {
-                return ((int)(this["KeepMinCP"]));
-            }
-            set {
-                this["KeepMinCP"] = value;
-            }
-        }
-
-        [global::System.Configuration.UserScopedSettingAttribute()]
-        [global::System.Diagnostics.DebuggerNonUserCodeAttribute()]
-        [global::System.Configuration.DefaultSettingValueAttribute("250")]
-        public double WalkingSpeedInKilometerPerHour {
-            get {
-                return ((double)(this["WalkingSpeedInKilometerPerHour"]));
-            }
-            set {
-                this["WalkingSpeedInKilometerPerHour"] = value;
-            }
-        }
-
-        [global::System.Configuration.UserScopedSettingAttribute()]
-        [global::System.Diagnostics.DebuggerNonUserCodeAttribute()]
-        [global::System.Configuration.DefaultSettingValueAttribute("0")]
-        public double DefaultLatitude {
-            get {
-                return ((double)(this["DefaultLatitude"]));
-            }
-            set {
-                this["DefaultLatitude"] = value;
-            }
-        }
-
-        [global::System.Configuration.UserScopedSettingAttribute()]
-        [global::System.Diagnostics.DebuggerNonUserCodeAttribute()]
-        [global::System.Configuration.DefaultSettingValueAttribute("0")]
-        public double DefaultLongitude {
-            get {
-                return ((double)(this["DefaultLongitude"]));
-            }
-            set {
-                this["DefaultLongitude"] = value;
-            }
-        }
-
-        [global::System.Configuration.UserScopedSettingAttribute()]
-        [global::System.Diagnostics.DebuggerNonUserCodeAttribute()]
-        [global::System.Configuration.DefaultSettingValueAttribute("False")]
-        public bool EvolveAllPokemonWithEnoughCandy {
-            get {
-                return ((bool)(this["EvolveAllPokemonWithEnoughCandy"]));
-            }
-            set {
-                this["EvolveAllPokemonWithEnoughCandy"] = value;
-            }
-        }
-
-        [global::System.Configuration.UserScopedSettingAttribute()]
-        [global::System.Diagnostics.DebuggerNonUserCodeAttribute()]
-        [global::System.Configuration.DefaultSettingValueAttribute("True")]
-        public bool TransferDuplicatePokemon {
-            get {
-                return ((bool)(this["TransferDuplicatePokemon"]));
-            }
-            set {
-                this["TransferDuplicatePokemon"] = value;
-            }
-        }
-
-        [global::System.Configuration.UserScopedSettingAttribute()]
-        [global::System.Diagnostics.DebuggerNonUserCodeAttribute()]
-        [global::System.Configuration.DefaultSettingValueAttribute("False")]
-        public bool UsePokemonToNotCatchFilter {
-            get {
-                return ((bool)(this["UsePokemonToNotCatchFilter"]));
-            }
-            set {
-                this["UsePokemonToNotCatchFilter"] = value;
-            }
-        }
-
-        [global::System.Configuration.UserScopedSettingAttribute()]
-        [global::System.Diagnostics.DebuggerNonUserCodeAttribute()]
-        [global::System.Configuration.DefaultSettingValueAttribute("2")]
-        public int KeepMinDuplicatePokemon {
-            get {
-                return ((int)(this["KeepMinDuplicatePokemon"]));
-            }
-            set {
-                this["KeepMinDuplicatePokemon"] = value;
-            }
-        }
-
-        [global::System.Configuration.UserScopedSettingAttribute()]
-        [global::System.Diagnostics.DebuggerNonUserCodeAttribute()]
-        [global::System.Configuration.DefaultSettingValueAttribute("Google")]
-        public string AuthType {
-            get {
-                return ((string)(this["AuthType"]));
-            }
-            set {
-                this["AuthType"] = value;
-            }
-        }
-
-        [global::System.Configuration.UserScopedSettingAttribute()]
-        [global::System.Diagnostics.DebuggerNonUserCodeAttribute()]
-        [global::System.Configuration.DefaultSettingValueAttribute("username")]
-        public string PtcUsername {
-            get {
-                return ((string)(this["PtcUsername"]));
-            }
-            set {
-                this["PtcUsername"] = value;
-            }
-        }
-
-        [global::System.Configuration.UserScopedSettingAttribute()]
-        [global::System.Diagnostics.DebuggerNonUserCodeAttribute()]
-        [global::System.Configuration.DefaultSettingValueAttribute("password")]
-        public string PtcPassword {
-            get {
-                return ((string)(this["PtcPassword"]));
-            }
-            set {
-                this["PtcPassword"] = value;
-            }
-        }
-
-        [global::System.Configuration.UserScopedSettingAttribute()]
-        [global::System.Diagnostics.DebuggerNonUserCodeAttribute()]
-        [global::System.Configuration.DefaultSettingValueAttribute("True")]
-        public bool PrioritizeIVOverCP {
-            get {
-                return ((bool)(this["PrioritizeIVOverCP"]));
-            }
-            set {
-                this["PrioritizeIVOverCP"] = value;
-            }
-        }
-
-        [global::System.Configuration.UserScopedSettingAttribute()]
-        [global::System.Diagnostics.DebuggerNonUserCodeAttribute()]
-        [global::System.Configuration.DefaultSettingValueAttribute("1000")]
-        public int MaxTravelDistanceInMeters {
-            get {
-                return ((int)(this["MaxTravelDistanceInMeters"]));
-            }
-            set {
-                this["MaxTravelDistanceInMeters"] = value;
-            }
-        }
-
-        [global::System.Configuration.UserScopedSettingAttribute()]
-        [global::System.Diagnostics.DebuggerNonUserCodeAttribute()]
-        [global::System.Configuration.DefaultSettingValueAttribute("False")]
-        public bool UseGPXPathing {
-            get {
-                return ((bool)(this["UseGPXPathing"]));
-            }
-            set {
-                this["UseGPXPathing"] = value;
-            }
-        }
-
-        [global::System.Configuration.UserScopedSettingAttribute()]
-        [global::System.Diagnostics.DebuggerNonUserCodeAttribute()]
-        [global::System.Configuration.DefaultSettingValueAttribute("GPXFile.GPX")]
-        public string GPXFile {
-            get {
-                return ((string)(this["GPXFile"]));
-            }
-            set {
-                this["GPXFile"] = value;
-            }
-        }
-    }
-}
diff --git a/PokemonGo.RocketAPI.Console/UserSettings.cs b/PokemonGo.RocketAPI.Console/UserSettings.cs
deleted file mode 100644
index 1d72304..0000000
--- a/PokemonGo.RocketAPI.Console/UserSettings.cs
+++ /dev/null
@@ -1,28 +0,0 @@
-#region
-
-using System.ComponentModel;
-using System.Configuration;
-
-#endregion
-
-
-namespace PokemonGo.RocketAPI.Console
-{
-    // This class allows you to handle specific events on the settings class:
-    //  The SettingChanging event is raised before a setting's value is changed.
-    //  The PropertyChanged event is raised after a setting's value is changed.
-    //  The SettingsLoaded event is raised after the setting values are loaded.
-    //  The SettingsSaving event is raised before the setting values are saved.
-    internal sealed partial class UserSettings
-    {
-        private void SettingChangingEventHandler(object sender, SettingChangingEventArgs e)
-        {
-            // Add code to handle the SettingChangingEvent event here.
-        }
-
-        private void SettingsSavingEventHandler(object sender, CancelEventArgs e)
-        {
-            // Add code to handle the SettingsSaving event here.
-        }
-    }
-}
\ No newline at end of file
diff --git a/PokemonGo.RocketAPI.Console/UserSettings.settings b/PokemonGo.RocketAPI.Console/UserSettings.settings
deleted file mode 100644
index 7ce5045..0000000
--- a/PokemonGo.RocketAPI.Console/UserSettings.settings
+++ /dev/null
@@ -1,57 +0,0 @@
-<?xml version='1.0' encoding='utf-8'?>
-<SettingsFile xmlns="http://schemas.microsoft.com/VisualStudio/2004/01/settings" CurrentProfile="(Default)" GeneratedClassNamespace="PokemonGo.RocketAPI.Console" GeneratedClassName="UserSettings">
-  <Profiles />
-  <Settings>
-    <Setting Name="DefaultAltitude" Type="System.Double" Scope="User">
-      <Value Profile="(Default)">10</Value>
-    </Setting>
-    <Setting Name="KeepMinIVPercentage" Type="System.Single" Scope="User">
-      <Value Profile="(Default)">85</Value>
-    </Setting>
-    <Setting Name="KeepMinCP" Type="System.Int32" Scope="User">
-      <Value Profile="(Default)">1000</Value>
-    </Setting>
-    <Setting Name="WalkingSpeedInKilometerPerHour" Type="System.Double" Scope="User">
-      <Value Profile="(Default)">250</Value>
-    </Setting>
-    <Setting Name="DefaultLatitude" Type="System.Double" Scope="User">
-      <Value Profile="(Default)">0</Value>
-    </Setting>
-    <Setting Name="DefaultLongitude" Type="System.Double" Scope="User">
-      <Value Profile="(Default)">0</Value>
-    </Setting>
-    <Setting Name="EvolveAllPokemonWithEnoughCandy" Type="System.Boolean" Scope="User">
-      <Value Profile="(Default)">False</Value>
-    </Setting>
-    <Setting Name="TransferDuplicatePokemon" Type="System.Boolean" Scope="User">
-      <Value Profile="(Default)">True</Value>
-    </Setting>
-    <Setting Name="UsePokemonToNotCatchFilter" Type="System.Boolean" Scope="User">
-      <Value Profile="(Default)">False</Value>
-    </Setting>
-    <Setting Name="KeepMinDuplicatePokemon" Type="System.Int32" Scope="User">
-      <Value Profile="(Default)">2</Value>
-    </Setting>
-    <Setting Name="AuthType" Type="System.String" Scope="User">
-      <Value Profile="(Default)">Google</Value>
-    </Setting>
-    <Setting Name="PtcUsername" Type="System.String" Scope="User">
-      <Value Profile="(Default)">username</Value>
-    </Setting>
-    <Setting Name="PtcPassword" Type="System.String" Scope="User">
-      <Value Profile="(Default)">password</Value>
-    </Setting>
-    <Setting Name="PrioritizeIVOverCP" Type="System.Boolean" Scope="User">
-      <Value Profile="(Default)">True</Value>
-    </Setting>
-    <Setting Name="MaxTravelDistanceInMeters" Type="System.Int32" Scope="User">
-      <Value Profile="(Default)">1000</Value>
-    </Setting>
-    <Setting Name="UseGPXPathing" Type="System.Boolean" Scope="User">
-      <Value Profile="(Default)">False</Value>
-    </Setting>
-    <Setting Name="GPXFile" Type="System.String" Scope="User">
-      <Value Profile="(Default)">GPXFile.GPX</Value>
-    </Setting>
-  </Settings>
-</SettingsFile>
\ No newline at end of file
diff --git a/PokemonGo.RocketAPI.Console/packages.config b/PokemonGo.RocketAPI.Console/packages.config
deleted file mode 100644
index cb70682..0000000
--- a/PokemonGo.RocketAPI.Console/packages.config
+++ /dev/null
@@ -1,4 +0,0 @@
-<?xml version="1.0" encoding="utf-8"?>
-<packages>
-  <package id="Google.Protobuf" version="3.0.0-beta3" targetFramework="net45" />
-</packages>
\ No newline at end of file
diff --git a/PokemonGo.RocketAPI.Logic/Inventory.cs b/PokemonGo.RocketAPI.Logic/Inventory.cs
deleted file mode 100644
index 069b8da..0000000
--- a/PokemonGo.RocketAPI.Logic/Inventory.cs
+++ /dev/null
@@ -1,251 +0,0 @@
-#region
-
-using System.Collections.Generic;
-using System.Linq;
-using System.Threading.Tasks;
-using PokemonGo.RocketAPI.Enums;
-using PokemonGo.RocketAPI.GeneratedCode;
-using System.Collections.Concurrent;
-using System;
-using System.Threading;
-
-#endregion
-
-
-namespace PokemonGo.RocketAPI.Logic
-{
-    public class Inventory
-    {
-        private readonly Client _client;
-        public static DateTime _lastRefresh;
-        public static GetInventoryResponse _cachedInventory;
-
-        public Inventory(Client client)
-        {
-            _client = client;
-        }
-
-        public async Task<IEnumerable<PokemonData>> GetDuplicatePokemonToTransfer(bool keepPokemonsThatCanEvolve = false, bool prioritizeIVoverCP = false, IEnumerable<PokemonId> filter = null)
-        {
-            var myPokemon = await GetPokemons();
-
-            var pokemonList = myPokemon.Where(p => p.DeployedFortId == 0 && p.Favorite == 0 && p.Cp < _client.Settings.KeepMinCP).ToList();
-            if (filter != null)
-                pokemonList = pokemonList.Where(p => !filter.Contains(p.PokemonId)).ToList();
-
-            if (keepPokemonsThatCanEvolve)
-            {
-                var results = new List<PokemonData>();
-                var pokemonsThatCanBeTransfered = pokemonList.GroupBy(p => p.PokemonId)
-                    .Where(x => x.Count() > 2).ToList();
-
-                var myPokemonSettings = await GetPokemonSettings();
-                var pokemonSettings = myPokemonSettings.ToList();
-
-                var myPokemonFamilies = await GetPokemonFamilies();
-                var pokemonFamilies = myPokemonFamilies.ToArray();
-
-                foreach (var pokemon in pokemonsThatCanBeTransfered)
-                {
-                    var settings = pokemonSettings.Single(x => x.PokemonId == pokemon.Key);
-                    var familyCandy = pokemonFamilies.Single(x => settings.FamilyId == x.FamilyId);
-                    if (settings.CandyToEvolve == 0)
-                        continue;
-
-                    var amountToSkip = familyCandy.Candy / settings.CandyToEvolve;
-                    if (prioritizeIVoverCP)
-                    {
-                        results.AddRange(pokemonList.Where(x => x.PokemonId == pokemon.Key)
-                            .OrderByDescending(x => PokemonInfo.CalculatePokemonPerfection(x))
-                            .ThenBy(n => n.StaminaMax)
-                            .Skip(amountToSkip)
-                            .ToList());
-                    }
-                    else
-                    {
-                        results.AddRange(pokemonList.Where(x => x.PokemonId == pokemon.Key)
-                            .OrderByDescending(x => x.Cp)
-                            .ThenBy(n => n.StaminaMax)
-                            .Skip(amountToSkip)
-                            .ToList());
-                    }
-                }
-
-                return results;
-            }
-            if (prioritizeIVoverCP)
-            {
-                return pokemonList
-                .GroupBy(p => p.PokemonId)
-                .Where(x => x.Count() > 1)
-                .SelectMany(
-                    p =>
-                        p.OrderByDescending(x => PokemonInfo.CalculatePokemonPerfection(x))
-                            .ThenBy(n => n.StaminaMax)
-                            .Skip(_client.Settings.KeepMinDuplicatePokemon)
-                            .ToList());
-            }
-            else
-            {
-                return pokemonList
-                .GroupBy(p => p.PokemonId)
-                .Where(x => x.Count() > 1)
-                .SelectMany(
-                    p =>
-                        p.OrderByDescending(x => x.Cp)
-                            .ThenBy(n => n.StaminaMax)
-                            .Skip(_client.Settings.KeepMinDuplicatePokemon)
-                            .ToList());
-            }
-        }
-
-        public async Task<IEnumerable<PokemonData>> GetHighestsCP(int limit)
-        {
-            var myPokemon = await GetPokemons();
-            var pokemons = myPokemon.ToList();
-            return pokemons.OrderByDescending(x => x.Cp).ThenBy(n => n.StaminaMax).Take(limit);
-        }
-
-        public async Task<IEnumerable<PokemonData>> GetHighestsPerfect(int limit)
-        {
-            var myPokemon = await GetPokemons();
-            var pokemons = myPokemon.ToList();
-            return pokemons.OrderByDescending(PokemonInfo.CalculatePokemonPerfection).Take(limit);
-        }
-
-        public async Task<PokemonData> GetHighestPokemonOfTypeByCP(PokemonData pokemon)
-        {
-            var myPokemon = await GetPokemons();
-            var pokemons = myPokemon.ToList();
-            return pokemons.Where(x => x.PokemonId == pokemon.PokemonId)
-                .OrderByDescending(x => x.Cp)
-                .FirstOrDefault();
-        }
-
-        public async Task<int> GetItemAmountByType(MiscEnums.Item type)
-        {
-            var pokeballs = await GetItems();
-            return pokeballs.FirstOrDefault(i => (MiscEnums.Item)i.Item_ == type)?.Count ?? 0;
-        }
-
-        public async Task<IEnumerable<Item>> GetItems()
-        {
-            var inventory = await getCachedInventory(_client);
-            return inventory.InventoryDelta.InventoryItems
-                .Select(i => i.InventoryItemData?.Item)
-                .Where(p => p != null);
-        }
-
-        public async Task<IEnumerable<Item>> GetItemsToRecycle(ISettings settings)
-        {
-            var myItems = await GetItems();
-
-            return myItems
-                .Where(x => settings.ItemRecycleFilter.Any(f => f.Key == (ItemId)x.Item_ && x.Count > f.Value))
-                .Select(
-                    x =>
-                        new Item
-                        {
-                            Item_ = x.Item_,
-                            Count = x.Count - settings.ItemRecycleFilter.Single(f => f.Key == (ItemId)x.Item_).Value,
-                            Unseen = x.Unseen
-                        });
-        }
-
-        public async Task<IEnumerable<PlayerStats>> GetPlayerStats()
-        {
-            var inventory = await getCachedInventory(_client);
-            return inventory.InventoryDelta.InventoryItems
-                .Select(i => i.InventoryItemData?.PlayerStats)
-                .Where(p => p != null);
-        }
-
-        public async Task<IEnumerable<PokemonFamily>> GetPokemonFamilies()
-        {
-            var inventory = await getCachedInventory(_client);
-            return
-                inventory.InventoryDelta.InventoryItems.Select(i => i.InventoryItemData?.PokemonFamily)
-                    .Where(p => p != null && p.FamilyId != PokemonFamilyId.FamilyUnset);
-        }
-
-        public async Task<IEnumerable<PokemonData>> GetPokemons()
-        {
-            var inventory = await getCachedInventory(_client);
-            return
-                inventory.InventoryDelta.InventoryItems.Select(i => i.InventoryItemData?.Pokemon)
-                    .Where(p => p != null && p.PokemonId > 0);
-        }
-
-        public async Task<IEnumerable<PokemonSettings>> GetPokemonSettings()
-        {
-            var templates = await _client.GetItemTemplates();
-            return
-                templates.ItemTemplates.Select(i => i.PokemonSettings)
-                    .Where(p => p != null && p.FamilyId != PokemonFamilyId.FamilyUnset);
-        }
-
-
-        public async Task<IEnumerable<PokemonData>> GetPokemonToEvolve(IEnumerable<PokemonId> filter = null)
-        {
-            var myPokemons = await GetPokemons();
-            myPokemons = myPokemons.Where(p => p.DeployedFortId == 0).OrderBy(p => p.Cp); //Don't evolve pokemon in gyms
-            if (filter != null)
-            {
-                myPokemons = myPokemons.Where(p => filter.Contains(p.PokemonId));
-            }
-            var pokemons = myPokemons.ToList();
-
-            var myPokemonSettings = await GetPokemonSettings();
-            var pokemonSettings = myPokemonSettings.ToList();
-
-            var myPokemonFamilies = await GetPokemonFamilies();
-            var pokemonFamilies = myPokemonFamilies.ToArray();
-
-            var pokemonToEvolve = new List<PokemonData>();
-            foreach (var pokemon in pokemons)
-            {
-                var settings = pokemonSettings.Single(x => x.PokemonId == pokemon.PokemonId);
-                var familyCandy = pokemonFamilies.Single(x => settings.FamilyId == x.FamilyId);
-
-                //Don't evolve if we can't evolve it
-                if (settings.EvolutionIds.Count == 0)
-                    continue;
-
-                var pokemonCandyNeededAlready =
-                    pokemonToEvolve.Count(
-                        p => pokemonSettings.Single(x => x.PokemonId == p.PokemonId).FamilyId == settings.FamilyId) *
-                    settings.CandyToEvolve;
-                if (familyCandy.Candy - pokemonCandyNeededAlready > settings.CandyToEvolve)
-                    pokemonToEvolve.Add(pokemon);
-            }
-
-            return pokemonToEvolve;
-        }
-
-        public static async Task<GetInventoryResponse> getCachedInventory(Client _client, bool request = false)
-        {
-            var now = DateTime.UtcNow;
-            SemaphoreSlim ss = new SemaphoreSlim(10);
-
-            if (_lastRefresh != null && _lastRefresh.AddSeconds(30).Ticks > now.Ticks && request == false)
-            {
-                return _cachedInventory;
-            }
-            else
-            {
-                await ss.WaitAsync();
-                try
-                {
-                    _lastRefresh = now;
-                    _cachedInventory = await _client.GetInventory();
-                    return _cachedInventory;
-                }
-                finally
-                {
-                    ss.Release();
-                }
-            }
-        }
-
-    }
-}
diff --git a/PokemonGo.RocketAPI.Logic/Logic.cs b/PokemonGo.RocketAPI.Logic/Logic.cs
deleted file mode 100644
index 14bc0f2..0000000
--- a/PokemonGo.RocketAPI.Logic/Logic.cs
+++ /dev/null
@@ -1,643 +0,0 @@
-#region
-
-using System;
-using System.Collections.Generic;
-using System.Device.Location;
-using System.Linq;
-using System.Threading;
-using System.Threading.Tasks;
-using PokemonGo.RocketAPI.Enums;
-using PokemonGo.RocketAPI.Exceptions;
-using PokemonGo.RocketAPI.Extensions;
-using PokemonGo.RocketAPI.GeneratedCode;
-using PokemonGo.RocketAPI.Logic.Utils;
-using PokemonGo.RocketAPI.Helpers;
-using System.IO;
-using System.Text;
-using PokemonGo.RocketAPI.Logging;
-
-#endregion
-
-
-namespace PokemonGo.RocketAPI.Logic
-{
-    public class Logic
-    {
-        private readonly Client _client;
-        private readonly ISettings _clientSettings;
-        private readonly Inventory _inventory;
-        private readonly Statistics _stats;
-        private readonly Navigation _navigation;
-        private GetPlayerResponse _playerProfile;
-
-        private int recycleCounter = 0;
-
-        public Logic(ISettings clientSettings)
-        {
-            _clientSettings = clientSettings;
-            _client = new Client(_clientSettings);
-            _inventory = new Inventory(_client);
-            _stats = new Statistics();
-            _navigation = new Navigation(_client);
-        }
-
-        public async Task Execute()
-        {
-            Git.CheckVersion();
-
-            if (_clientSettings.DefaultLatitude == 0 || _clientSettings.DefaultLongitude == 0)
-            {
-                Logger.Write($"Please change first Latitude and/or Longitude because currently your using default values!", LogLevel.Error);
-                Logger.Write($"Window will be auto closed in 15 seconds!", LogLevel.Error);
-                await Task.Delay(15000);
-                System.Environment.Exit(1);
-            } else
-            {
-                Logger.Write($"Make sure Lat & Lng is right. Exit Program if not! Lat: {_client.CurrentLat} Lng: {_client.CurrentLng}", LogLevel.Warning);
-                for (int i = 3; i > 0; i--)
-                {
-                    Logger.Write($"Script will continue in {i * 5} seconds!", LogLevel.Warning);
-                    await Task.Delay(5000);
-                }
-            }
-
-            Logger.Write($"Logging in via: {_clientSettings.AuthType}", LogLevel.Info);
-            while (true)
-            {
-                try
-                {
-                    switch (_clientSettings.AuthType)
-                    {
-                        case AuthType.Ptc:
-                            await _client.DoPtcLogin(_clientSettings.PtcUsername, _clientSettings.PtcPassword);
-                            break;
-                        case AuthType.Google:
-                            await _client.DoGoogleLogin("GoogleAuth.ini");
-                            break;
-                        default:
-                            Logger.Write("wrong AuthType");
-                            Environment.Exit(0);
-                            break;
-                    }
-
-                    await _client.SetServer();
-
-                    await PostLoginExecute();
-                }
-                catch (Exception e)
-                {
-                    Logger.Write(e.Message + " from " + e.Source);
-                    Logger.Write("Got an exception, trying automatic restart..", LogLevel.Error);
-                    await Execute();
-                }
-                await Task.Delay(10000);
-            }
-        }
-
-        public async Task PostLoginExecute()
-        {
-            Logger.Write($"Client logged in", LogLevel.Info);
-
-            while (true)
-            {
-                await Inventory.getCachedInventory(_client);
-                _playerProfile = await _client.GetProfile();
-                var PlayerName = Statistics.GetUsername(_client, _playerProfile);
-                _stats.UpdateConsoleTitle(_inventory);
-                var _currentLevelInfos = await Statistics._getcurrentLevelInfos(_inventory);
-
-                Logger.Write("----------------------------", LogLevel.None, ConsoleColor.Yellow);
-                if (_clientSettings.AuthType == AuthType.Ptc)
-                    Logger.Write($"PTC Account: {PlayerName}\n", LogLevel.None, ConsoleColor.Cyan);
-                Logger.Write($"Latitude: {_clientSettings.DefaultLatitude}", LogLevel.None, ConsoleColor.DarkGray);
-                Logger.Write($"Longitude: {_clientSettings.DefaultLongitude}", LogLevel.None, ConsoleColor.DarkGray);
-                Logger.Write("----------------------------", LogLevel.None, ConsoleColor.Yellow);
-                Logger.Write("Your Account:\n");
-                Logger.Write($"Name: {PlayerName}", LogLevel.None, ConsoleColor.DarkGray);
-                Logger.Write($"Team: {_playerProfile.Profile.Team}", LogLevel.None, ConsoleColor.DarkGray);
-                Logger.Write($"Level: {_currentLevelInfos}", LogLevel.None, ConsoleColor.DarkGray);
-                Logger.Write($"Stardust: {_playerProfile.Profile.Currency.ToArray()[1].Amount}", LogLevel.None, ConsoleColor.DarkGray);
-                Logger.Write("----------------------------", LogLevel.None, ConsoleColor.Yellow);
-                await DisplayHighests();
-                Logger.Write("----------------------------", LogLevel.None, ConsoleColor.Yellow);
-
-                var PokemonsNotToTransfer = _clientSettings.PokemonsNotToTransfer;
-                var PokemonsNotToCatch = _clientSettings.PokemonsNotToCatch;
-                var PokemonsToEvolve = _clientSettings.PokemonsToEvolve;
-
-                if (_clientSettings.EvolveAllPokemonWithEnoughCandy) await EvolveAllPokemonWithEnoughCandy(_clientSettings.PokemonsToEvolve);
-                if (_clientSettings.TransferDuplicatePokemon) await TransferDuplicatePokemon();
-                await PokemonToCSV();
-                await RecycleItems();
-                await ExecuteFarmingPokestopsAndPokemons(_clientSettings.UseGPXPathing);
-
-                /*
-            * Example calls below
-            *
-            var profile = await _client.GetProfile();
-            var settings = await _client.GetSettings();
-            var mapObjects = await _client.GetMapObjects();
-            var inventory = await _client.GetInventory();
-            var pokemons = inventory.InventoryDelta.InventoryItems.Select(i => i.InventoryItemData?.Pokemon).Where(p => p != null && p?.PokemonId > 0);
-            */
-
-                await Task.Delay(10000);
-            }
-        }
-
-        private async Task ExecuteFarmingPokestopsAndPokemons(bool path = false)
-        {
-            if (!path)
-                await ExecuteFarmingPokestopsAndPokemons();
-            else
-            {
-                //bool onTrack = true;
-                List<GPXReader.trk> Tracks = GetGPXTracks(_clientSettings.GPXFile);
-                int curTrkPt = 0;
-                int maxTrkPt = 0;
-                int curTrk = 0;
-                int maxTrk = Tracks.Count - 1;
-                int curTrkSeg = 0;
-                int maxTrkSeg = 0;
-                while (curTrk <= maxTrk)
-                {
-                    var Track = Tracks.ElementAt(curTrk);
-                    var trackSegments = Track.Segments;
-                    maxTrkSeg = trackSegments.Count - 1;
-                    while (curTrkSeg <= maxTrkSeg)
-                    {
-                        List<GPXReader.trkpt> TrackPoints = Track.Segments.ElementAt(0).TrackPoints;
-                        maxTrkPt = TrackPoints.Count - 1;
-                        var mapObjects = await _client.GetMapObjects();
-                        while (curTrkPt <= maxTrkPt)
-                        {
-                            GPXReader.trkpt nextPoint = TrackPoints.ElementAt(curTrkPt);
-                            if (LocationUtils.CalculateDistanceInMeters(_client.CurrentLat, _client.CurrentLng, Convert.ToDouble(nextPoint.Lat), Convert.ToDouble(nextPoint.Lon)) > 5000)
-                            {
-                                Logger.Write($"Your desired destination of {nextPoint.Lat}, {nextPoint.Lon} is too far from your current position of {_client.CurrentLat}, {_client.CurrentLng}", LogLevel.Error);
-                                break;
-                            }
-
-                            Logger.Write($"Your desired destination is {nextPoint.Lat}, your location is {nextPoint.Lon} {_client.CurrentLat}, {_client.CurrentLng}", LogLevel.Warning);
-
-                            // Wasn't sure how to make this pretty. Edit as needed.
-                            var pokeStops =
-                                mapObjects.MapCells.SelectMany(i => i.Forts)
-                                    .Where(
-                                        i =>
-                                            i.Type == FortType.Checkpoint &&
-                                            i.CooldownCompleteTimestampMs < DateTime.UtcNow.ToUnixTime() &&
-                                            ( // Make sure PokeStop is within 40 meters, otherwise we cannot hit them.
-                                            LocationUtils.CalculateDistanceInMeters(
-                                                _client.CurrentLat, _client.CurrentLng,
-                                                    i.Latitude, i.Longitude) < 40)
-                                            );
-
-                            var pokestopList = pokeStops.ToList();
-
-                            while (pokestopList.Any())
-                            {
-                                pokestopList = pokestopList.OrderBy(i => LocationUtils.CalculateDistanceInMeters(_client.CurrentLat, _client.CurrentLng, i.Latitude, i.Longitude)).ToList();
-                                var pokeStop = pokestopList[0];
-                                pokestopList.RemoveAt(0);
-
-                                var fortInfo = await _client.GetFort(pokeStop.Id, pokeStop.Latitude, pokeStop.Longitude);
-
-                                var fortSearch = await _client.SearchFort(pokeStop.Id, pokeStop.Latitude, pokeStop.Longitude);
-                                if (fortSearch.ExperienceAwarded > 0)
-                                {
-                                    _stats.AddExperience(fortSearch.ExperienceAwarded);
-                                    _stats.UpdateConsoleTitle(_inventory);
-                                    //todo: fix egg crash
-                                    Logger.Write($"XP: {fortSearch.ExperienceAwarded}, Gems: {fortSearch.GemsAwarded}, Items: {StringUtils.GetSummedFriendlyNameOfItemAwardList(fortSearch.ItemsAwarded)}", LogLevel.Pokestop);
-                                }
-
-                                await Task.Delay(1000);
-                                await RecycleItems();
-                                if (_clientSettings.TransferDuplicatePokemon) await TransferDuplicatePokemon();
-
-
-                            }
-
-                            var update = await _navigation.HumanPathWalking(TrackPoints.ElementAt(curTrkPt), _clientSettings.WalkingSpeedInKilometerPerHour, ExecuteCatchAllNearbyPokemons);
-
-                            if (curTrkPt >= maxTrkPt)
-                                curTrkPt = 0;
-                            else
-                                curTrkPt++;
-
-                        }//end trkpts
-                        if (curTrkSeg >= maxTrkSeg)
-                            curTrkSeg = 0;
-                        else
-                            curTrkSeg++;
-                    }//end trksegs
-                    if (curTrk >= maxTrkSeg)
-                        curTrk = 0;
-                    else
-                        curTrk++;
-                }//end tracks
-            }
-        }
-        private async Task ExecuteFarmingPokestopsAndPokemons()
-        {
-            var distanceFromStart = LocationUtils.CalculateDistanceInMeters(
-                _clientSettings.DefaultLatitude, _clientSettings.DefaultLongitude,
-                _client.CurrentLat, _client.CurrentLng);
-
-            // Edge case for when the client somehow ends up outside the defined radius
-            if (_clientSettings.MaxTravelDistanceInMeters != 0 &&
-                distanceFromStart > _clientSettings.MaxTravelDistanceInMeters)
-            {
-                Logger.Write($"You're outside of your defined radius! Walking to start in 5 seconds...", LogLevel.Warning);
-                await Task.Delay(5000);
-                var update = await _navigation.HumanLikeWalking(
-                    new GeoCoordinate(_clientSettings.DefaultLatitude, _clientSettings.DefaultLongitude),
-                    _clientSettings.WalkingSpeedInKilometerPerHour, null);
-                var ToStart = await _navigation.HumanLikeWalking(
-                    new GeoCoordinate(_clientSettings.DefaultLatitude, _clientSettings.DefaultLongitude),
-                    _clientSettings.WalkingSpeedInKilometerPerHour, ExecuteCatchAllNearbyPokemons);
-            }
-
-            var mapObjects = await _client.GetMapObjects();
-
-            var pokeStops =
-                Navigation.pathByNearestNeighbour(
-                mapObjects.MapCells.SelectMany(i => i.Forts)
-                    .Where(
-                        i =>
-                            i.Type == FortType.Checkpoint &&
-                            i.CooldownCompleteTimestampMs < DateTime.UtcNow.ToUnixTime() &&
-                            (_clientSettings.MaxTravelDistanceInMeters == 0 ||
-                            LocationUtils.CalculateDistanceInMeters(
-                                _clientSettings.DefaultLatitude, _clientSettings.DefaultLongitude,
-                                    i.Latitude, i.Longitude) < _clientSettings.MaxTravelDistanceInMeters))
-                            .OrderBy(
-                            i =>
-                            LocationUtils.CalculateDistanceInMeters(_client.CurrentLat, _client.CurrentLng, i.Latitude, i.Longitude)).ToArray());
-            var pokestopList = pokeStops.ToList();
-            if (pokestopList.Count <= 0)
-            {
-                Logger.Write($"No PokeStops within {_clientSettings.MaxTravelDistanceInMeters}m. Choose a different GPS location or increase MaxTravelDistanceInMeters.", LogLevel.Error);
-                return;
-            }
-            Logger.Write($"Found {pokeStops.Count()} pokestops", LogLevel.None, ConsoleColor.Green);
-
-            foreach (var pokeStop in pokeStops)
-            {
-                await ExecuteCatchAllNearbyPokemons();
-
-                var distance = LocationUtils.CalculateDistanceInMeters(_client.CurrentLat, _client.CurrentLng, pokeStop.Latitude, pokeStop.Longitude);
-                var fortInfo = await _client.GetFort(pokeStop.Id, pokeStop.Latitude, pokeStop.Longitude);
-
-                Logger.Write($"Name: {fortInfo.Name} in {distance:0.##} m distance", LogLevel.Pokestop);
-                var update = await _navigation.HumanLikeWalking(new GeoCoordinate(pokeStop.Latitude, pokeStop.Longitude), _clientSettings.WalkingSpeedInKilometerPerHour, ExecuteCatchAllNearbyPokemons);
-
-                var fortSearch = await _client.SearchFort(pokeStop.Id, pokeStop.Latitude, pokeStop.Longitude);
-                if (fortSearch.ExperienceAwarded > 0)
-                {
-                    _stats.AddExperience(fortSearch.ExperienceAwarded);
-                    _stats.UpdateConsoleTitle(_inventory);
-                    string EggReward = fortSearch.PokemonDataEgg != null ? "1" : "0";
-                    Logger.Write($"XP: {fortSearch.ExperienceAwarded}, Gems: {fortSearch.GemsAwarded}, Eggs: {EggReward}, Items: {StringUtils.GetSummedFriendlyNameOfItemAwardList(fortSearch.ItemsAwarded)}", LogLevel.Pokestop);
-                    recycleCounter++;
-                }
-                await RandomHelper.RandomDelay(50, 200);
-                if (recycleCounter >= 5)
-                    await RecycleItems();
-            }
-        }
-
-        private async Task CatchEncounter(EncounterResponse encounter, MapPokemon pokemon)
-        {
-            CatchPokemonResponse caughtPokemonResponse;
-            int attemptCounter = 1;
-            do
-            {
-                var bestBerry = await GetBestBerry(encounter?.WildPokemon);
-                var inventoryBerries = await _inventory.GetItems();
-                var probability = encounter?.CaptureProbability?.CaptureProbability_?.FirstOrDefault();
-
-                var bestPokeball = await GetBestBall(encounter?.WildPokemon);
-                if (bestPokeball == MiscEnums.Item.ITEM_UNKNOWN)
-                {
-                    Logger.Write($"You don't own any Pokeballs :( - We missed a {pokemon.PokemonId} with CP {encounter?.WildPokemon?.PokemonData?.Cp}", LogLevel.Warning);
-                    return;
-                }
-
-                var berries = inventoryBerries.Where(p => (ItemId)p.Item_ == bestBerry).FirstOrDefault();
-                if (bestBerry != ItemId.ItemUnknown && probability.HasValue && probability.Value < 0.35 && PokemonInfo.CalculatePokemonPerfection(encounter?.WildPokemon?.PokemonData) >= _clientSettings.KeepMinIVPercentage)
-                {
-                    var useRaspberry = await _client.UseCaptureItem(pokemon.EncounterId, bestBerry, pokemon.SpawnpointId);
-                    Logger.Write($"{bestBerry} used, remaining: {berries.Count}", LogLevel.Berry);
-                    await RandomHelper.RandomDelay(50, 200);
-                }
-
-                var distance = LocationUtils.CalculateDistanceInMeters(_client.CurrentLat, _client.CurrentLng, pokemon.Latitude, pokemon.Longitude);
-                caughtPokemonResponse = await _client.CatchPokemon(pokemon.EncounterId, pokemon.SpawnpointId, pokemon.Latitude, pokemon.Longitude, bestPokeball);
-
-                if (caughtPokemonResponse.Status == CatchPokemonResponse.Types.CatchStatus.CatchSuccess)
-                {
-                    foreach (int xp in caughtPokemonResponse.Scores.Xp)
-                        _stats.AddExperience(xp);
-                    _stats.IncreasePokemons();
-                    var profile = await _client.GetProfile();
-                    _stats.GetStardust(profile.Profile.Currency.ToArray()[1].Amount);
-                }
-                _stats.UpdateConsoleTitle(_inventory);
-
-                if (encounter?.CaptureProbability?.CaptureProbability_ != null)
-                {
-                    string catchStatus = attemptCounter > 1 ? $"{caughtPokemonResponse.Status} Attempt #{attemptCounter}" : $"{caughtPokemonResponse.Status}";
-                    string receivedXP = catchStatus == "CatchSuccess" ? $"and received XP {caughtPokemonResponse.Scores.Xp.Sum()}" : $"";
-                    Logger.Write($"({catchStatus}) | {pokemon.PokemonId} Lvl {PokemonInfo.GetLevel(encounter?.WildPokemon?.PokemonData)} (CP {encounter?.WildPokemon?.PokemonData?.Cp}/{PokemonInfo.CalculateMaxCP(encounter?.WildPokemon?.PokemonData)} | {Math.Round(PokemonInfo.CalculatePokemonPerfection(encounter?.WildPokemon?.PokemonData)).ToString("0.00")} % perfect) | Chance: {(float)((int)(encounter?.CaptureProbability?.CaptureProbability_.First() * 100)) / 100} | {Math.Round(distance)}m dist | with {bestPokeball} {receivedXP}", LogLevel.Pokemon);
-                }
-
-                attemptCounter++;
-                await RandomHelper.RandomDelay(750, 1250);
-            }
-            while (caughtPokemonResponse.Status == CatchPokemonResponse.Types.CatchStatus.CatchMissed || caughtPokemonResponse.Status == CatchPokemonResponse.Types.CatchStatus.CatchEscape);
-        }
-
-        private async Task ExecuteCatchAllNearbyPokemons()
-        {
-            var mapObjects = await _client.GetMapObjects();
-
-            var pokemons =
-                mapObjects.MapCells.SelectMany(i => i.CatchablePokemons)
-                .OrderBy(
-                    i =>
-                    LocationUtils.CalculateDistanceInMeters(_client.CurrentLat, _client.CurrentLng, i.Latitude, i.Longitude));
-
-            if (_clientSettings.UsePokemonToNotCatchFilter)
-            {
-                ICollection<PokemonId> filter = _clientSettings.PokemonsNotToCatch;
-                pokemons = mapObjects.MapCells.SelectMany(i => i.CatchablePokemons).Where(p => !filter.Contains(p.PokemonId)).OrderBy(i => LocationUtils.CalculateDistanceInMeters(_client.CurrentLat, _client.CurrentLng, i.Latitude, i.Longitude));
-            }
-
-            if (pokemons != null && pokemons.Any())
-                Logger.Write($"Found {pokemons.Count()} catchable Pokemon", LogLevel.None, ConsoleColor.Green);
-            else
-                return;
-
-            foreach (var pokemon in pokemons)
-            {
-                var distance = LocationUtils.CalculateDistanceInMeters(_client.CurrentLat, _client.CurrentLng, pokemon.Latitude, pokemon.Longitude);
-                await Task.Delay(distance > 100 ? 1000 : 100);
-
-                var encounter = await _client.EncounterPokemon(pokemon.EncounterId, pokemon.SpawnpointId);
-
-                if (encounter.Status == EncounterResponse.Types.Status.EncounterSuccess)
-                    await CatchEncounter(encounter, pokemon);
-                else
-                    Logger.Write($"Encounter problem: {encounter.Status}", LogLevel.Warning);
-                if (pokemons.ElementAtOrDefault(pokemons.Count() - 1) != pokemon)
-                    await RandomHelper.RandomDelay(50, 200);
-            }
-
-            if (_clientSettings.EvolveAllPokemonWithEnoughCandy) await EvolveAllPokemonWithEnoughCandy(_clientSettings.PokemonsToEvolve);
-            if (_clientSettings.TransferDuplicatePokemon) await TransferDuplicatePokemon();
-        }
-
-        private async Task EvolveAllPokemonWithEnoughCandy(IEnumerable<PokemonId> filter = null)
-        {
-            await Inventory.getCachedInventory(_client, true);
-            var pokemonToEvolve = await _inventory.GetPokemonToEvolve(filter);
-            if (pokemonToEvolve != null && pokemonToEvolve.Any())
-                Logger.Write($"{pokemonToEvolve.Count()} Pokemon:", LogLevel.Evolve);
-
-            foreach (var pokemon in pokemonToEvolve)
-            {
-                var evolvePokemonOutProto = await _client.EvolvePokemon((ulong)pokemon.Id);
-
-                Logger.Write(
-                    evolvePokemonOutProto.Result == EvolvePokemonOut.Types.EvolvePokemonStatus.PokemonEvolvedSuccess
-                        ? $"{pokemon.PokemonId} successfully for {evolvePokemonOutProto.ExpAwarded} xp"
-                        : $"Failed: {pokemon.PokemonId}. EvolvePokemonOutProto.Result was {evolvePokemonOutProto.Result}, stopping evolving {pokemon.PokemonId}"
-                    , LogLevel.Evolve);
-
-                await Task.Delay(1000);
-            }
-        }
-
-        private async Task TransferDuplicatePokemon(bool keepPokemonsThatCanEvolve = false)
-        {
-            await Inventory.getCachedInventory(_client, true);
-            var duplicatePokemons = await _inventory.GetDuplicatePokemonToTransfer(keepPokemonsThatCanEvolve, _clientSettings.PrioritizeIVOverCP, _clientSettings.PokemonsNotToTransfer);
-            if (duplicatePokemons != null && duplicatePokemons.Any())
-                Logger.Write($"{duplicatePokemons.Count()} Pokemon:", LogLevel.Transfer);
-
-            foreach (var duplicatePokemon in duplicatePokemons)
-            {
-                var transfer = await _client.TransferPokemon(duplicatePokemon.Id);
-
-                _stats.IncreasePokemonsTransfered();
-                _stats.UpdateConsoleTitle(_inventory);
-
-                var bestPokemonOfType = await _inventory.GetHighestPokemonOfTypeByCP(duplicatePokemon);
-                Logger.Write($"{duplicatePokemon.PokemonId} (CP {duplicatePokemon.Cp} | {PokemonInfo.CalculatePokemonPerfection(duplicatePokemon).ToString("0.00")} % perfect) | (Best: {bestPokemonOfType.Cp} CP | {PokemonInfo.CalculatePokemonPerfection(bestPokemonOfType).ToString("0.00")} % perfect)", LogLevel.Transfer);
-                await Task.Delay(500);
-            }
-        }
-
-        private async Task RecycleItems()
-        {
-            await Inventory.getCachedInventory(_client, true);
-            var items = await _inventory.GetItemsToRecycle(_clientSettings);
-            if (items != null && items.Any())
-                Logger.Write($"{items.Count()} {(items.Count() == 1 ? "Item" : "Items")}:", LogLevel.Recycling);
-
-            foreach (var item in items)
-            {
-                var transfer = await _client.RecycleItem((ItemId)item.Item_, item.Count);
-                Logger.Write($"{item.Count}x {(ItemId)item.Item_}", LogLevel.Recycling);
-
-                _stats.AddItemsRemoved(item.Count);
-                _stats.UpdateConsoleTitle(_inventory);
-
-                await Task.Delay(100);
-            }
-            recycleCounter = 0;
-        }
-
-        private async Task<MiscEnums.Item> GetBestBall(WildPokemon pokemon)
-        {
-            var pokemonCp = pokemon?.PokemonData?.Cp;
-
-            var items = await _inventory.GetItems();
-            var balls = items.Where(i => ((MiscEnums.Item)i.Item_ == MiscEnums.Item.ITEM_POKE_BALL
-                                      || (MiscEnums.Item)i.Item_ == MiscEnums.Item.ITEM_GREAT_BALL
-                                      || (MiscEnums.Item)i.Item_ == MiscEnums.Item.ITEM_ULTRA_BALL
-                                      || (MiscEnums.Item)i.Item_ == MiscEnums.Item.ITEM_MASTER_BALL) && i.Count > 0).GroupBy(i => ((MiscEnums.Item)i.Item_)).ToList();
-            if (balls.Count == 0) return MiscEnums.Item.ITEM_UNKNOWN;
-
-            var pokeBalls = balls.Any(g => g.Key == MiscEnums.Item.ITEM_POKE_BALL);
-            var greatBalls = balls.Any(g => g.Key == MiscEnums.Item.ITEM_GREAT_BALL);
-            var ultraBalls = balls.Any(g => g.Key == MiscEnums.Item.ITEM_ULTRA_BALL);
-            var masterBalls = balls.Any(g => g.Key == MiscEnums.Item.ITEM_MASTER_BALL);
-
-            if (masterBalls && pokemonCp >= 2000)
-                return MiscEnums.Item.ITEM_MASTER_BALL;
-            else if (ultraBalls && pokemonCp >= 2000)
-                return MiscEnums.Item.ITEM_ULTRA_BALL;
-            else if (greatBalls && pokemonCp >= 2000)
-                return MiscEnums.Item.ITEM_GREAT_BALL;
-
-            if (ultraBalls && pokemonCp >= 1000)
-                return MiscEnums.Item.ITEM_ULTRA_BALL;
-            else if (greatBalls && pokemonCp >= 1000)
-                return MiscEnums.Item.ITEM_GREAT_BALL;
-
-            if (greatBalls && pokemonCp >= 500)
-                return MiscEnums.Item.ITEM_GREAT_BALL;
-
-            return balls.OrderBy(g => g.Key).First().Key;
-        }
-
-        private async Task<ItemId> GetBestBerry(WildPokemon pokemon)
-        {
-            var pokemonCp = pokemon?.PokemonData?.Cp;
-
-            var items = await _inventory.GetItems();
-            var berries = items.Where(i => (ItemId)i.Item_ == ItemId.ItemRazzBerry
-                                        || (ItemId)i.Item_ == ItemId.ItemBlukBerry
-                                        || (ItemId)i.Item_ == ItemId.ItemNanabBerry
-                                        || (ItemId)i.Item_ == ItemId.ItemWeparBerry
-                                        || (ItemId)i.Item_ == ItemId.ItemPinapBerry).GroupBy(i => ((ItemId)i.Item_)).ToList();
-            if (berries.Count == 0 || pokemonCp <= 350) return ItemId.ItemUnknown;
-
-            var razzBerryCount = await _inventory.GetItemAmountByType(MiscEnums.Item.ITEM_RAZZ_BERRY);
-            var blukBerryCount = await _inventory.GetItemAmountByType(MiscEnums.Item.ITEM_BLUK_BERRY);
-            var nanabBerryCount = await _inventory.GetItemAmountByType(MiscEnums.Item.ITEM_NANAB_BERRY);
-            var weparBerryCount = await _inventory.GetItemAmountByType(MiscEnums.Item.ITEM_WEPAR_BERRY);
-            var pinapBerryCount = await _inventory.GetItemAmountByType(MiscEnums.Item.ITEM_PINAP_BERRY);
-
-            if (pinapBerryCount > 0 && pokemonCp >= 2000)
-                return ItemId.ItemPinapBerry;
-            else if (weparBerryCount > 0 && pokemonCp >= 2000)
-                return ItemId.ItemWeparBerry;
-            else if (nanabBerryCount > 0 && pokemonCp >= 2000)
-                return ItemId.ItemNanabBerry;
-            else if (nanabBerryCount > 0 && pokemonCp >= 2000)
-                return ItemId.ItemBlukBerry;
-
-            if (weparBerryCount > 0 && pokemonCp >= 1500)
-                return ItemId.ItemWeparBerry;
-            else if (nanabBerryCount > 0 && pokemonCp >= 1500)
-                return ItemId.ItemNanabBerry;
-            else if (blukBerryCount > 0 && pokemonCp >= 1500)
-                return ItemId.ItemBlukBerry;
-
-            if (nanabBerryCount > 0 && pokemonCp >= 1000)
-                return ItemId.ItemNanabBerry;
-            else if (blukBerryCount > 0 && pokemonCp >= 1000)
-                return ItemId.ItemBlukBerry;
-
-            if (blukBerryCount > 0 && pokemonCp >= 500)
-                return ItemId.ItemBlukBerry;
-
-            return berries.OrderBy(g => g.Key).First().Key;
-        }
-
-        private async Task DisplayPlayerLevelInTitle(bool updateOnly = false)
-        {
-            _playerProfile = _playerProfile.Profile != null ? _playerProfile : await _client.GetProfile();
-            var playerName = _playerProfile.Profile.Username ?? "";
-            var playerStats = await _inventory.GetPlayerStats();
-            var playerStat = playerStats.FirstOrDefault();
-            if (playerStat != null)
-            {
-                var message =
-                    $" {playerName} | Level {playerStat.Level:0} - ({playerStat.Experience - playerStat.PrevLevelXp:0} / {playerStat.NextLevelXp - playerStat.PrevLevelXp:0} XP)";
-                Console.Title = message;
-                if (updateOnly == false)
-                    Logger.Write(message);
-            }
-            if (updateOnly == false)
-                await Task.Delay(5000);
-        }
-
-        private async Task DisplayHighests()
-        {
-            Logger.Write($"====== DisplayHighestsCP ======", LogLevel.Info, ConsoleColor.Yellow);
-            var highestsPokemonCP = await _inventory.GetHighestsCP(10);
-            foreach (var pokemon in highestsPokemonCP)
-                Logger.Write($"# CP {pokemon.Cp.ToString().PadLeft(4, ' ')}/{PokemonInfo.CalculateMaxCP(pokemon).ToString().PadLeft(4, ' ')} | ({PokemonInfo.CalculatePokemonPerfection(pokemon).ToString("0.00")}% perfect)\t| Lvl {PokemonInfo.GetLevel(pokemon).ToString("00")}\t NAME: '{pokemon.PokemonId}'");
-            Logger.Write($"====== DisplayHighestsPerfect ======", LogLevel.Info, ConsoleColor.Yellow);
-            var highestsPokemonPerfect = await _inventory.GetHighestsPerfect(10);
-            foreach (var pokemon in highestsPokemonPerfect)
-            {
-                Logger.Write($"# CP {pokemon.Cp.ToString().PadLeft(4, ' ')}/{PokemonInfo.CalculateMaxCP(pokemon).ToString().PadLeft(4, ' ')} | ({PokemonInfo.CalculatePokemonPerfection(pokemon).ToString("0.00")}% perfect)\t| Lvl {PokemonInfo.GetLevel(pokemon).ToString("00")}\t NAME: '{pokemon.PokemonId}'");
-            }
-        }
-
-        private async Task PokemonToCSV(string filename = "PokeList.csv")
-        {
-            string path = Directory.GetCurrentDirectory() + "\\Export\\";
-            if (!Directory.Exists(path))
-                Directory.CreateDirectory(path);
-            if (Directory.Exists(path))
-            {
-                try
-                {
-                    if (File.Exists(path + filename))
-                        File.Delete(path + filename);
-                    if (!File.Exists(path + filename))
-                    {
-                        var AllPokemon = await _inventory.GetHighestsPerfect(1000);
-                        var csvExportPokemonAll = new StringBuilder();
-                        var columnnames = string.Format("{0};{1};{2};{3}", "#", "NAME", "CP", "PERFECTION");
-                        csvExportPokemonAll.AppendLine(columnnames);
-                        foreach (var pokemon in AllPokemon)
-                        {
-                            int POKENUMBER = (int)pokemon.PokemonId;
-                            var NAME = $"{pokemon.PokemonId}";
-                            var CP = $"{pokemon.Cp}";
-                            string PERFECTION = PokemonInfo.CalculatePokemonPerfection(pokemon).ToString("0.00");
-                            var pokedata = string.Format("{0};{1};{2};{3}", POKENUMBER, NAME, CP, PERFECTION);
-                            csvExportPokemonAll.AppendLine(pokedata);
-                        }
-                        Logger.Write($"Export all Pokemon to \"\\Export\\{filename}\"", LogLevel.Info);
-                        File.WriteAllText(path + filename, csvExportPokemonAll.ToString());
-                    }
-                }
-                catch
-                {
-                    Logger.Write("Export all Pokemons to CSV not possible. File seems be in use!", LogLevel.Warning);
-                }
-            }
-        }
-
-        private async Task LoadAndDisplayGPXFile()
-        {
-            string xmlString = File.ReadAllText(_clientSettings.GPXFile);
-            GPXReader Readgpx = new GPXReader(xmlString);
-            foreach (GPXReader.trk trk in Readgpx.Tracks)
-            {
-                foreach (GPXReader.trkseg trkseg in trk.Segments)
-                {
-                    foreach (GPXReader.trkpt trpkt in trkseg.TrackPoints)
-                    {
-                        Console.WriteLine(trpkt.ToString());
-                    }
-                }
-            }
-            await Task.Delay(0);
-        }
-
-        private GPXReader.trk GetGPXTrack(string gpxFile)
-        {
-            string xmlString = File.ReadAllText(_clientSettings.GPXFile);
-            GPXReader Readgpx = new GPXReader(xmlString);
-            return Readgpx.Tracks.ElementAt(0);
-        }
-
-        private List<GPXReader.trk> GetGPXTracks(string gpxFile)
-        {
-            string xmlString = File.ReadAllText(_clientSettings.GPXFile);
-            GPXReader Readgpx = new GPXReader(xmlString);
-            return Readgpx.Tracks;
-        }
-
-    }
-}
\ No newline at end of file
diff --git a/PokemonGo.RocketAPI.Logic/Navigation.cs b/PokemonGo.RocketAPI.Logic/Navigation.cs
deleted file mode 100644
index 857b49d..0000000
--- a/PokemonGo.RocketAPI.Logic/Navigation.cs
+++ /dev/null
@@ -1,162 +0,0 @@
-#region
-
-using System;
-using System.Device.Location;
-using System.Threading.Tasks;
-using PokemonGo.RocketAPI.GeneratedCode;
-using PokemonGo.RocketAPI.Logic.Utils;
-using PokemonGo.RocketAPI.Logging;
-
-#endregion
-
-
-namespace PokemonGo.RocketAPI.Logic
-{
-    public class Navigation
-    {
-
-        private const double SpeedDownTo = 10 / 3.6;
-        private readonly Client _client;
-
-        public Navigation(Client client)
-        {
-            _client = client;
-        }
-
-        public async Task<PlayerUpdateResponse> HumanLikeWalking(GeoCoordinate targetLocation,
-            double walkingSpeedInKilometersPerHour, Func<Task> functionExecutedWhileWalking)
-        {
-            var speedInMetersPerSecond = walkingSpeedInKilometersPerHour / 3.6;
-
-            var sourceLocation = new GeoCoordinate(_client.CurrentLat, _client.CurrentLng);
-            var distanceToTarget = LocationUtils.CalculateDistanceInMeters(sourceLocation, targetLocation);
-            Logger.Write($"Distance to target location: {distanceToTarget:0.##} meters. Will take {distanceToTarget / speedInMetersPerSecond:0.##} seconds!", LogLevel.Navigation);
-
-            var nextWaypointBearing = LocationUtils.DegreeBearing(sourceLocation, targetLocation);
-            var nextWaypointDistance = speedInMetersPerSecond;
-            var waypoint = LocationUtils.CreateWaypoint(sourceLocation, nextWaypointDistance, nextWaypointBearing);
-
-            //Initial walking
-            var requestSendDateTime = DateTime.Now;
-            var result =
-                await
-                    _client.UpdatePlayerLocation(waypoint.Latitude, waypoint.Longitude, _client.Settings.DefaultAltitude);
-            do
-            {
-                var millisecondsUntilGetUpdatePlayerLocationResponse =
-                    (DateTime.Now - requestSendDateTime).TotalMilliseconds;
-
-                sourceLocation = new GeoCoordinate(_client.CurrentLat, _client.CurrentLng);
-                var currentDistanceToTarget = LocationUtils.CalculateDistanceInMeters(sourceLocation, targetLocation);
-
-                if (currentDistanceToTarget < 40)
-                {
-                    if (speedInMetersPerSecond > SpeedDownTo)
-                    {
-                        Logger.Write($"We are within 40 meters of the target. Speeding down to 10 km/h to not pass the target.", LogLevel.Navigation);
-                        speedInMetersPerSecond = SpeedDownTo;
-                    }
-                }
-
-                nextWaypointDistance = Math.Min(currentDistanceToTarget,
-                    millisecondsUntilGetUpdatePlayerLocationResponse / 1000 * speedInMetersPerSecond);
-                nextWaypointBearing = LocationUtils.DegreeBearing(sourceLocation, targetLocation);
-                waypoint = LocationUtils.CreateWaypoint(sourceLocation, nextWaypointDistance, nextWaypointBearing);
-
-                requestSendDateTime = DateTime.Now;
-                result =
-                    await
-                        _client.UpdatePlayerLocation(waypoint.Latitude, waypoint.Longitude,
-                            _client.Settings.DefaultAltitude);
-                if (functionExecutedWhileWalking != null)
-                    await functionExecutedWhileWalking();// look for pokemon
-                await Task.Delay(Math.Min((int)(distanceToTarget / speedInMetersPerSecond * 100), 3000));
-            } while (LocationUtils.CalculateDistanceInMeters(sourceLocation, targetLocation) >= 30);
-
-            return result;
-        }
-
-        public async Task<PlayerUpdateResponse> HumanPathWalking(GPXReader.trkpt trk, double walkingSpeedInKilometersPerHour, Func<Task> functionExecutedWhileWalking)
-        {
-            //PlayerUpdateResponse result = null;
-
-            var targetLocation = new GeoCoordinate(Convert.ToDouble(trk.Lat), Convert.ToDouble(trk.Lon));
-
-            var speedInMetersPerSecond = walkingSpeedInKilometersPerHour / 3.6;
-
-            var sourceLocation = new GeoCoordinate(_client.CurrentLat, _client.CurrentLng);
-            var distanceToTarget = LocationUtils.CalculateDistanceInMeters(sourceLocation, targetLocation);
-            // Logger.Write($"Distance to target location: {distanceToTarget:0.##} meters. Will take {distanceToTarget/speedInMetersPerSecond:0.##} seconds!", LogLevel.Info);
-
-            var nextWaypointBearing = LocationUtils.DegreeBearing(sourceLocation, targetLocation);
-            var nextWaypointDistance = speedInMetersPerSecond;
-            var waypoint = LocationUtils.CreateWaypoint(sourceLocation, nextWaypointDistance, nextWaypointBearing, Convert.ToDouble(trk.Ele));
-
-            //Initial walking
-
-            var requestSendDateTime = DateTime.Now;
-            var result =
-                await
-                    _client.UpdatePlayerLocation(waypoint.Latitude, waypoint.Longitude, waypoint.Altitude);
-
-            do
-            {
-                var millisecondsUntilGetUpdatePlayerLocationResponse =
-                    (DateTime.Now - requestSendDateTime).TotalMilliseconds;
-
-                sourceLocation = new GeoCoordinate(_client.CurrentLat, _client.CurrentLng);
-                var currentDistanceToTarget = LocationUtils.CalculateDistanceInMeters(sourceLocation, targetLocation);
-
-                //if (currentDistanceToTarget < 40)
-                //{
-                //    if (speedInMetersPerSecond > SpeedDownTo)
-                //    {
-                //        //Logger.Write("We are within 40 meters of the target. Speeding down to 10 km/h to not pass the target.", LogLevel.Info);
-                //        speedInMetersPerSecond = SpeedDownTo;
-                //    }
-                //}
-
-                nextWaypointDistance = Math.Min(currentDistanceToTarget,
-                    millisecondsUntilGetUpdatePlayerLocationResponse / 1000 * speedInMetersPerSecond);
-                nextWaypointBearing = LocationUtils.DegreeBearing(sourceLocation, targetLocation);
-                waypoint = LocationUtils.CreateWaypoint(sourceLocation, nextWaypointDistance, nextWaypointBearing);
-
-                requestSendDateTime = DateTime.Now;
-                result =
-                    await
-                        _client.UpdatePlayerLocation(waypoint.Latitude, waypoint.Longitude,
-                            waypoint.Altitude);
-                if (functionExecutedWhileWalking != null)
-                    await functionExecutedWhileWalking();// look for pokemon
-                await Task.Delay(Math.Min((int)(distanceToTarget / speedInMetersPerSecond * 1000), 3000));
-            } while (LocationUtils.CalculateDistanceInMeters(sourceLocation, targetLocation) >= 30);
-
-            return result;
-        }
-
-        public static FortData[] pathByNearestNeighbour(FortData[] pokeStops)
-        {
-            for (var i = 1; i < pokeStops.Length - 1; i++)
-            {
-                var closest = i + 1;
-                var cloestDist = LocationUtils.CalculateDistanceInMeters(pokeStops[i].Latitude, pokeStops[i].Longitude, pokeStops[closest].Latitude, pokeStops[closest].Longitude);
-                for (var j = closest; j < pokeStops.Length; j++)
-                {
-                    var initialDist = cloestDist;
-                    var newDist = LocationUtils.CalculateDistanceInMeters(pokeStops[i].Latitude, pokeStops[i].Longitude, pokeStops[j].Latitude, pokeStops[j].Longitude);
-                    if (initialDist > newDist)
-                    {
-                        cloestDist = newDist;
-                        closest = j;
-                    }
-
-                }
-                var tmpPok = pokeStops[closest];
-                pokeStops[closest] = pokeStops[i + 1];
-                pokeStops[i + 1] = tmpPok;
-            }
-
-            return pokeStops;
-        }
-    }
-}
\ No newline at end of file
diff --git a/PokemonGo.RocketAPI.Logic/PokemonGo.RocketAPI.Logic.csproj b/PokemonGo.RocketAPI.Logic/PokemonGo.RocketAPI.Logic.csproj
deleted file mode 100644
index c3ce1c7..0000000
--- a/PokemonGo.RocketAPI.Logic/PokemonGo.RocketAPI.Logic.csproj
+++ /dev/null
@@ -1,80 +0,0 @@
-<?xml version="1.0" encoding="utf-8"?>
-<Project ToolsVersion="14.0" DefaultTargets="Build" xmlns="http://schemas.microsoft.com/developer/msbuild/2003">
-  <Import Project="$(MSBuildExtensionsPath)\$(MSBuildToolsVersion)\Microsoft.Common.props" Condition="Exists('$(MSBuildExtensionsPath)\$(MSBuildToolsVersion)\Microsoft.Common.props')" />
-  <PropertyGroup>
-    <Configuration Condition=" '$(Configuration)' == '' ">Debug</Configuration>
-    <Platform Condition=" '$(Platform)' == '' ">AnyCPU</Platform>
-    <ProjectGuid>{0739E40D-C589-4AEB-93E5-EE8CD6773C60}</ProjectGuid>
-    <OutputType>Library</OutputType>
-    <AppDesignerFolder>Properties</AppDesignerFolder>
-    <RootNamespace>PokemonGo.RocketAPI.Logic</RootNamespace>
-    <AssemblyName>PokemonGo.RocketAPI.Logic</AssemblyName>
-    <TargetFrameworkVersion>v4.5</TargetFrameworkVersion>
-    <FileAlignment>512</FileAlignment>
-    <PrimaryVersionType>AssemblyVersionAttribute</PrimaryVersionType>
-    <AssemblyInfoFilePath>..\PokemonGo.RocketAPI\Properties\AssemblyInfo.cs</AssemblyInfoFilePath>
-    <UpdateAssemblyVersion>True</UpdateAssemblyVersion>
-    <UpdateAssemblyFileVersion>False</UpdateAssemblyFileVersion>
-    <UpdateAssemblyInfoVersion>False</UpdateAssemblyInfoVersion>
-    <AssemblyVersionSettings>YearStamp.MonthStamp.DayStamp.Increment</AssemblyVersionSettings>
-  </PropertyGroup>
-  <PropertyGroup Condition=" '$(Configuration)|$(Platform)' == 'Debug|AnyCPU' ">
-    <DebugSymbols>true</DebugSymbols>
-    <DebugType>full</DebugType>
-    <Optimize>false</Optimize>
-    <OutputPath>bin\Debug\</OutputPath>
-    <DefineConstants>DEBUG;TRACE</DefineConstants>
-    <ErrorReport>prompt</ErrorReport>
-    <WarningLevel>4</WarningLevel>
-  </PropertyGroup>
-  <PropertyGroup Condition=" '$(Configuration)|$(Platform)' == 'Release|AnyCPU' ">
-    <DebugType>pdbonly</DebugType>
-    <Optimize>true</Optimize>
-    <OutputPath>bin\Release\</OutputPath>
-    <DefineConstants>TRACE</DefineConstants>
-    <ErrorReport>prompt</ErrorReport>
-    <WarningLevel>4</WarningLevel>
-  </PropertyGroup>
-  <ItemGroup>
-    <Reference Include="Google.Protobuf">
-      <HintPath>..\PokemonGo.RocketAPI\bin\Debug\Google.Protobuf.dll</HintPath>
-    </Reference>
-    <Reference Include="System" />
-    <Reference Include="System.Configuration" />
-    <Reference Include="System.Core" />
-    <Reference Include="System.Device" />
-    <Reference Include="System.Xml.Linq" />
-    <Reference Include="System.Data.DataSetExtensions" />
-    <Reference Include="Microsoft.CSharp" />
-    <Reference Include="System.Data" />
-    <Reference Include="System.Net.Http" />
-    <Reference Include="System.Xml" />
-  </ItemGroup>
-  <ItemGroup>
-    <Compile Include="Inventory.cs" />
-    <Compile Include="Logic.cs" />
-    <Compile Include="Navigation.cs" />
-    <Compile Include="Properties\AssemblyInfo.cs" />
-    <Compile Include="Utils\GPXReader.cs" />
-    <Compile Include="Utils\LocationUtils.cs" />
-    <Compile Include="Utils\Statistics.cs" />
-    <Compile Include="Utils\StringUtils.cs" />
-  </ItemGroup>
-  <ItemGroup>
-    <ProjectReference Include="..\PokemonGo.RocketAPI\PokemonGo.RocketAPI.csproj">
-      <Project>{05d2da44-1b8e-4cf7-94ed-4d52451cd095}</Project>
-      <Name>PokemonGo.RocketAPI</Name>
-    </ProjectReference>
-  </ItemGroup>
-  <ItemGroup>
-    <None Include="app.config" />
-  </ItemGroup>
-  <Import Project="$(MSBuildToolsPath)\Microsoft.CSharp.targets" />
-  <!-- To modify your build process, add your task inside one of the targets below and uncomment it.
-       Other similar extension points exist, see Microsoft.Common.targets.
-  <Target Name="BeforeBuild">
-  </Target>
-  <Target Name="AfterBuild">
-  </Target>
-  -->
-</Project>
\ No newline at end of file
diff --git a/PokemonGo.RocketAPI.Logic/Properties/AssemblyInfo.cs b/PokemonGo.RocketAPI.Logic/Properties/AssemblyInfo.cs
deleted file mode 100644
index 34c8f85..0000000
--- a/PokemonGo.RocketAPI.Logic/Properties/AssemblyInfo.cs
+++ /dev/null
@@ -1,36 +0,0 @@
-using System.Reflection;
-using System.Runtime.CompilerServices;
-using System.Runtime.InteropServices;
-
-// General Information about an assembly is controlled through the following
-// set of attributes. Change these attribute values to modify the information
-// associated with an assembly.
-[assembly: AssemblyTitle("PokemonGo.RocketAPI.Logic")]
-[assembly: AssemblyDescription("")]
-[assembly: AssemblyConfiguration("")]
-[assembly: AssemblyCompany("")]
-[assembly: AssemblyProduct("PokemonGo.RocketAPI.Logic")]
-[assembly: AssemblyCopyright("Copyright ©  2016")]
-[assembly: AssemblyTrademark("")]
-[assembly: AssemblyCulture("")]
-
-// Setting ComVisible to false makes the types in this assembly not visible
-// to COM components.  If you need to access a type in this assembly from
-// COM, set the ComVisible attribute to true on that type.
-[assembly: ComVisible(false)]
-
-// The following GUID is for the ID of the typelib if this project is exposed to COM
-[assembly: Guid("0739e40d-c589-4aeb-93e5-ee8cd6773c60")]
-
-// Version information for an assembly consists of the following four values:
-//
-//      Major Version
-//      Minor Version
-//      Build Number
-//      Revision
-//
-// You can specify all the values or you can default the Build and Revision Numbers
-// by using the '*' as shown below:
-// [assembly: AssemblyVersion("1.0.*")]
-[assembly: AssemblyVersion("2016.7.22.2")]
-[assembly: AssemblyFileVersion("1.0.0.0")]
diff --git a/PokemonGo.RocketAPI.Logic/Utils/GPXReader.cs b/PokemonGo.RocketAPI.Logic/Utils/GPXReader.cs
deleted file mode 100644
index 1cac8b2..0000000
--- a/PokemonGo.RocketAPI.Logic/Utils/GPXReader.cs
+++ /dev/null
@@ -1,723 +0,0 @@
-using PokemonGo.RocketAPI.Logging;
-using System;
-using System.Collections.Generic;
-using System.Xml;
-namespace PokemonGo.RocketAPI.Logic.Utils
-{
-    public class GPXReader
-    {
-        private XmlDocument _GPX = new XmlDocument();
-
-        private string _Name = "";
-
-        public string Name
-        {
-            get { return _Name; }
-            set { _Name = value; }
-        }
-
-        public string Description = "";
-        public string Author = "";
-        public string EMail = "";
-        public string Time = "";
-        public string KeyWords = "";
-        public string URL = "";
-        public string URLName = "";
-        public GPSBoundary Bounds = new GPSBoundary();
-        public List<wpt> WayPoints = new List<wpt>();
-        public List<rte> Routes = new List<rte>();
-        public List<trk> Tracks = new List<trk>();
-
-        public GPXReader(string XML)
-        {
-            if (!XML.Equals(""))
-            {
-                _GPX.LoadXml(XML);
-                if ((_GPX.DocumentElement).Name.Equals("gpx"))
-                {
-                    XmlNodeList GPXNodes = ((_GPX.GetElementsByTagName("gpx"))[0]).ChildNodes;
-                    foreach (XmlNode Node in GPXNodes)
-                    {
-
-                        switch (Node.Name)
-                        {
-                            case "name":
-                                Name = Node.InnerText;
-                                break;
-                            case "desc":
-                                Description = Node.InnerText;
-                                break;
-                            case "author":
-                                Author = Node.InnerText;
-                                break;
-                            case "email":
-                                EMail = Node.InnerText;
-                                break;
-                            case "time":
-                                Time = Node.InnerText;
-                                break;
-                            case "keywords":
-                                KeyWords = Node.InnerText;
-                                break;
-                            case "bounds":
-                                Bounds = new GPSBoundary();
-                                foreach (XmlAttribute Att in (Node).Attributes)
-                                {
-                                    switch (Att.Name)
-                                    {
-                                        case "minlat":
-                                            Bounds.Min.lat = Att.Value;
-                                            break;
-                                        case "minlon":
-                                            Bounds.Min.lon = Att.Value;
-                                            break;
-                                        case "maxlat":
-                                            Bounds.Max.lat = Att.Value;
-                                            break;
-                                        case "maxlon":
-                                            Bounds.Max.lon = Att.Value;
-                                            break;
-                                    }
-                                }
-                                break;
-                            case "wpt":
-                                wpt NewWayPoint = new wpt(Node);
-                                WayPoints.Add(NewWayPoint);
-                                break;
-                            case "rte":
-                                rte NewRoute = new rte(Node);
-                                Routes.Add(NewRoute);
-                                break;
-                            case "trk":
-                                trk Track = new trk(Node);
-                                Tracks.Add(Track);
-                                break;
-                            case "url":
-                                URL = Node.InnerText;
-                                break;
-                            case "urlname":
-                                URLName = Node.InnerText;
-                                break;
-                            case "topografix:active_point":
-                            case "topografix:map":
-                                break;
-                            default:
-                                Logger.Write("Unhandled data in GPX file, attempting to skip.", LogLevel.Info);
-                                break;
-                        }
-                    }
-                }
-            }
-        }
-
-        public class travelbug
-        {
-            public string ID = "";
-            public string Reference = "";
-            public string Groundspeak_Name = "";
-
-            public travelbug(XmlNode TravelBugNode)
-            {
-                ID = TravelBugNode.Attributes["id"].Value.ToString();
-                Reference = TravelBugNode.Attributes["ref"].Value.ToString();
-                foreach (XmlNode TBChildNode in TravelBugNode.ChildNodes)
-                {
-                    switch (TBChildNode.Name)
-                    {
-                        case "groundspeak:name":
-                            Groundspeak_Name = TBChildNode.InnerText;
-                            break;
-                        default:
-                            throw new Exception("Unhandled Child Node: " + TBChildNode.Name);
-                    }
-                }
-            }
-        }
-
-        public class cachelog
-        {
-            public string ID = "";
-            public string Groundspeak_Date = "";
-            public string Groundspeak_Type = "";
-            public string Groundspeak_Finder = "";
-            public string Groundspeak_FinderID = "";
-            public string Groundspeak_Text = "";
-            public string Groundspeak_TextEncoded = "";
-            public GPSCoordinates Groundspeak_LogWayPoint = new GPSCoordinates();
-
-            public cachelog(XmlNode ChildNode)
-            {
-                ID = ChildNode.Attributes["id"].Value.ToString();
-                foreach (XmlNode Node in ChildNode.ChildNodes)
-                {
-                    switch (Node.Name)
-                    {
-                        case "groundspeak:date":
-                            Groundspeak_Date = Node.InnerText;
-                            break;
-                        case "groundspeak:type":
-                            Groundspeak_Type = Node.InnerText;
-                            break;
-                        case "groundspeak:finder":
-                            Groundspeak_Finder = Node.InnerText;
-                            Groundspeak_FinderID = Node.Attributes["id"].Value.ToString();
-                            break;
-                        case "groundspeak:text":
-                            Groundspeak_Text = Node.InnerText;
-                            Groundspeak_TextEncoded = Node.Attributes["encoded"].Value.ToString();
-                            break;
-                        case "groundspeak:log_wpt":
-                            Groundspeak_LogWayPoint.lat = Node.Attributes["lat"].Value.ToString();
-                            Groundspeak_LogWayPoint.lon = Node.Attributes["lon"].Value.ToString();
-                            break;
-                        default:
-                            throw new Exception("Unhandled Child Node: " + Node.Name);
-                    }
-                }
-            }
-        }
-
-        public class cache
-        {
-            public string ID = "";
-            public string Available = "";
-            public string Archived = "";
-            public string Xmlns = "";
-
-            public string Groundspeak_Name = "";
-            public string Groundspeak_PlacedBy = "";
-            public string Groundspeak_Owner = "";
-            public string Groundspeak_OwnerID = "";
-            public string Groundspeak_Type = "";
-            public string Groundspeak_Container = "";
-            public string Groundspeak_Difficulty = "";
-            public string Groundspeak_Terrain = "";
-            public string Groundspeak_Country = "";
-            public string Groundspeak_State = "";
-            public string Groundspeak_ShortDescription = "";
-            public bool Groundspeak_ShortDescriptionIsHTML = false;
-            public string Groundspeak_LongDescription = "";
-            public bool Groundspeak_LongDescriptionIsHTML = false;
-            public string Groundspeak_EncodedHint = "";
-
-            public List<cachelog> Groundspeak_Logs = new List<cachelog>();
-            public List<travelbug> Groundspeak_Travelbugs = new List<travelbug>();
-            public List<Attribute> Groundspeak_Attributes = new List<Attribute>();
-
-            public cache(XmlNode Node)
-            {
-                #region Attributes
-
-                foreach (XmlAttribute Attribute in Node.Attributes)
-                {
-                    switch (Attribute.Name)
-                    {
-                        case "id":
-                            ID = Attribute.Value;
-                            break;
-                        case "available":
-                            Available = Attribute.Value;
-                            break;
-                        case "archived":
-                            Archived = Attribute.Value;
-                            break;
-                        case "xmlns:groundspeak":
-                            Xmlns = Attribute.Value;
-                            break;
-                        default:
-                            throw new Exception("Unhandled Attribute: " + Attribute.Name);
-                    }
-                }
-                #endregion Attributes
-
-                foreach (XmlNode ChildNode in Node.ChildNodes)
-                {
-                    switch (ChildNode.Name)
-                    {
-                        case "groundspeak:name":
-                            Groundspeak_Name = ChildNode.InnerText;
-                            break;
-                        case "groundspeak:placed_by":
-                            Groundspeak_PlacedBy = ChildNode.InnerText;
-                            break;
-                        case "groundspeak:owner":
-                            Groundspeak_Owner = ChildNode.InnerText;
-                            Groundspeak_OwnerID = ChildNode.Attributes["id"].Value.ToString();
-                            break;
-                        case "groundspeak:type":
-                            Groundspeak_Type = ChildNode.InnerText;
-                            break;
-                        case "groundspeak:container":
-                            Groundspeak_Container = ChildNode.InnerText;
-                            break;
-                        case "groundspeak:difficulty":
-                            Groundspeak_Difficulty = ChildNode.InnerText;
-                            break;
-                        case "groundspeak:terrain":
-                            Groundspeak_Terrain = ChildNode.InnerText;
-                            break;
-                        case "groundspeak:country":
-                            Groundspeak_Country = ChildNode.InnerText;
-                            break;
-                        case "groundspeak:state":
-                            Groundspeak_State = ChildNode.InnerText;
-                            break;
-                        case "groundspeak:short_description":
-                            Groundspeak_ShortDescription = ChildNode.InnerText;
-                            if (ChildNode.Attributes["html"].Value.Equals("True"))
-                            {
-                                Groundspeak_ShortDescriptionIsHTML = true;
-                            }
-                            break;
-                        case "groundspeak:long_description":
-                            Groundspeak_LongDescription = ChildNode.InnerText;
-                            if (ChildNode.Attributes["html"].Value.Equals("True"))
-                            {
-                                Groundspeak_LongDescriptionIsHTML = true;
-                            }
-                            break;
-                        case "groundspeak:encoded_hints":
-                            Groundspeak_EncodedHint = ChildNode.InnerText;
-                            break;
-                        case "groundspeak:logs":
-                            foreach (XmlNode LogNode in ChildNode.ChildNodes)
-                            {
-                                cachelog Groundspeak_LogEntry = new cachelog(LogNode);
-                                Groundspeak_Logs.Add(Groundspeak_LogEntry);
-                            }
-                            break;
-                        case "groundspeak:travelbugs":
-                            foreach (XmlNode TravelBugNode in ChildNode.ChildNodes)
-                            {
-                                travelbug Travelbug = new travelbug(TravelBugNode);
-                                Groundspeak_Travelbugs.Add(Travelbug);
-                            }
-                            break;
-                        case "groundspeak:attributes":
-                            foreach (XmlNode AttributeNode in ChildNode.ChildNodes)
-                            {
-                                Attribute CacheAttribute = new Attribute(AttributeNode);
-                                Groundspeak_Attributes.Add(CacheAttribute);
-                            }
-                            break;
-                        default:
-                            throw new Exception("Unhandled Child Node: " + ChildNode.Name);
-                    }
-                }
-            }
-
-            public cache()
-            {
-            }
-        }
-
-
-        //WayPoint contains Caches and other Objects
-
-        public class wpt
-        {
-            public GPSCoordinates Coordinates = new GPSCoordinates();
-            public string Name = "";
-            public string Desc = "";
-            public string Time = "";
-            public string URLName = "";
-            public string URL = "";
-            public string Sym = "";
-            public string Type = "";
-            public string Ele = "0";
-            public string Cmt = "";
-            public string Opencaching_Awesomeness = "";
-            public string Opencaching_Difficulty = "";
-            public string Opencaching_Terrain = "";
-            public string Opencaching_Size = "";
-            public string Opencaching_VerificationPhrase = "";
-            public string Opencaching_VerificationNumber = "";
-            public string Opencaching_VerificationQR = "";
-            public string Opencaching_VerificationChirp = "";
-            public string Opencaching_SeriesID = "";
-            public string Opencaching_SeriesName = "";
-            public List<string> Opencaching_Tags = new List<string>();
-
-            public cache Groundspeak_Cache = new cache();
-
-            public wpt(XmlNode Node)
-            {
-                Coordinates.lat = Node.Attributes["lat"].Value.ToString();
-                Coordinates.lon = Node.Attributes["lon"].Value.ToString();
-                foreach (XmlNode ChildNode in Node.ChildNodes)
-                {
-                    switch (ChildNode.Name)
-                    {
-                        case "time":
-                            Time = ChildNode.InnerText;
-                            break;
-                        case "name":
-                            Name = ChildNode.InnerText;
-                            break;
-                        case "desc":
-                            Desc = ChildNode.InnerText;
-                            break;
-                        case "url":
-                            URL = ChildNode.InnerText;
-                            break;
-                        case "urlname":
-                            URLName = ChildNode.InnerText;
-                            break;
-                        case "sym":
-                            Sym = ChildNode.InnerText;
-                            break;
-                        case "type":
-                            Type = ChildNode.InnerText;
-                            break;
-                        case "ele":
-                            Ele = ChildNode.InnerText;
-                            break;
-                        case "cmt":
-                            Cmt = ChildNode.InnerText;
-                            break;
-                        case "groundspeak:cache":
-                            Groundspeak_Cache = new cache(ChildNode);
-                            break;
-                        case "ox:opencaching":
-                            foreach (XmlNode OpenCachingChildNode in ChildNode.ChildNodes)
-                            {
-                                switch (OpenCachingChildNode.Name)
-                                {
-                                    case "ox:ratings":
-                                        foreach (XmlNode OpenCachingRatingsChildNode in OpenCachingChildNode.ChildNodes)
-                                        {
-                                            switch (OpenCachingRatingsChildNode.Name)
-                                            {
-                                                case "ox:awesomeness":
-                                                    Opencaching_Awesomeness = (OpenCachingRatingsChildNode).InnerText;
-                                                    break;
-                                                case "ox:difficulty":
-                                                    Opencaching_Difficulty = (OpenCachingRatingsChildNode).InnerText;
-                                                    break;
-                                                case "ox:terrain":
-                                                    Opencaching_Terrain = (OpenCachingRatingsChildNode).InnerText;
-                                                    break;
-                                                case "ox:size":
-                                                    Opencaching_Size = (OpenCachingRatingsChildNode).InnerText;
-                                                    break;
-                                                default:
-                                                    throw new Exception("Unhandled for Child Object: " + OpenCachingRatingsChildNode.Name);
-                                            }
-                                        }
-                                        break;
-                                    case "ox:tags":
-                                        foreach (XmlNode OpenCachingTagNode in OpenCachingChildNode.ChildNodes)
-                                        {
-                                            switch (OpenCachingTagNode.Name)
-                                            {
-                                                case "ox:tag":
-                                                    Opencaching_Tags.Add((OpenCachingTagNode).InnerXml);
-                                                    break;
-                                                default:
-                                                    throw new Exception("Unhandled for Child Object: " + OpenCachingTagNode.Name);
-                                            }
-                                        }
-
-                                        break;
-                                    case "ox:verification":
-                                        foreach (XmlNode OpenCachingVerificationNode in OpenCachingChildNode.ChildNodes)
-                                        {
-                                            switch (OpenCachingVerificationNode.Name)
-                                            {
-                                                case "ox:phrase":
-                                                    Opencaching_VerificationPhrase = OpenCachingChildNode.InnerText;
-                                                    break;
-                                                case "ox:number":
-                                                    Opencaching_VerificationNumber = OpenCachingChildNode.InnerText;
-                                                    break;
-                                                case "ox:QR":
-                                                    Opencaching_VerificationQR = OpenCachingChildNode.InnerText;
-                                                    break;
-                                                case "ox:chirp":
-                                                    Opencaching_VerificationChirp = OpenCachingChildNode.InnerText;
-                                                    break;
-                                                default:
-                                                    throw new Exception("Unhandled for Child Object: " + OpenCachingVerificationNode.Name);
-                                            }
-                                        }
-                                        break;
-                                    case "ox:series":
-                                        Opencaching_SeriesName = OpenCachingChildNode.InnerText;
-                                        Opencaching_SeriesID = (OpenCachingChildNode).Attributes["id"].Value.ToString();
-                                        break;
-                                    default:
-                                        throw new Exception("Unhandled for Child Object: " + OpenCachingChildNode.Name);
-                                }
-                            }
-                            break;
-                        default:
-                            throw new Exception("Unhandled for Child Object: " + ChildNode.Name);
-                    }
-                }
-            }
-        }
-
-        public class GPSBoundary
-        {
-            public GPSCoordinates Min = new GPSCoordinates();
-            public GPSCoordinates Max = new GPSCoordinates();
-
-            public GPSBoundary()
-            {
-            }
-        }
-
-        public class GPSCoordinates
-        {
-            public string lat = "";
-            public string lon = "";
-
-            public GPSCoordinates()
-            {
-            }
-        }
-
-        public class Attribute : IComparable<Attribute>
-        {
-            public string ID = "";
-            public string Inc = "";
-            public string Description = "";
-
-            public Attribute(XmlNode AttributeNode)
-            {
-                ID = AttributeNode.Attributes["id"].Value.ToString();
-                Inc = AttributeNode.Attributes["inc"].Value.ToString();
-                Description = AttributeNode.InnerText;
-            }
-
-            public Attribute()
-            {
-            }
-
-
-            public int CompareTo(Attribute other)
-            {
-                return this.Description.CompareTo(other.Description);
-
-            }
-        }
-
-        //Route ans Route Points
-
-        public class rte
-        {
-            public string Name = "";
-            public string Desc = "";
-            public string Number = "";
-            public string URL = "";
-            public string URLName = "";
-            List<rtept> RoutePoints = new List<rtept>();
-
-            public rte(XmlNode Node)
-            {
-                foreach (XmlNode ChildNode in Node.ChildNodes)
-                {
-                    switch (ChildNode.Name)
-                    {
-                        case "name":
-                            Name = ChildNode.InnerText;
-                            break;
-                        case "desc":
-                            Desc = ChildNode.InnerText;
-                            break;
-                        case "number":
-                            Number = ChildNode.InnerText;
-                            break;
-                        case "rtept":
-                            rtept RoutePoint = new rtept(ChildNode);
-                            RoutePoints.Add(RoutePoint);
-                            break;
-                        case "url":
-                            URL = ChildNode.InnerText;
-                            break;
-                        case "urlname":
-                            URLName = ChildNode.InnerText;
-                            break;
-                        case "topografix:color":
-                            break;
-                        default:
-                            throw new Exception("Unhandled for Child Object: " + ChildNode.Name);
-                    }
-                }
-            }
-        }
-
-        public class rtept
-        {
-            public string Lat = "";
-            public string Lon = "";
-            public string Ele = "";
-            public string Time = "";
-            public string Name = "";
-            public string Cmt = "";
-            public string Desc = "";
-            public string Sym = "";
-            public string Type = "";
-            public string URL = "";
-            public string URLName = "";
-
-            public rtept(XmlNode Node)
-            {
-                Lat = Node.Attributes["lat"].Value.ToString();
-                Lon = Node.Attributes["lon"].Value.ToString();
-                foreach (XmlNode ChildNode in Node.ChildNodes)
-                {
-                    switch (ChildNode.Name)
-                    {
-                        case "ele":
-                            Ele = ChildNode.InnerText;
-                            break;
-                        case "time":
-                            Time = ChildNode.InnerText;
-                            break;
-                        case "name":
-                            Name = ChildNode.InnerText;
-                            break;
-                        case "cmt":
-                            Cmt = ChildNode.InnerText;
-                            break;
-                        case "desc":
-                            Desc = ChildNode.InnerText;
-                            break;
-                        case "sym":
-                            Sym = ChildNode.InnerText;
-                            break;
-                        case "type":
-                            Type = ChildNode.InnerText;
-                            break;
-                        case "url":
-                            URL = ChildNode.InnerText;
-                            break;
-                        case "urlname":
-                            URLName = ChildNode.InnerText;
-                            break;
-                        case "topografix:leg":
-                            break;
-                        default:
-                            throw new Exception("Unhandled for Child Object: " + ChildNode.Name);
-                    }
-                }
-            }
-        }
-
-        //Tracks
-
-        public class trk
-        {
-            public string Name = "";
-            public string Desc = "";
-            public string Number = "";
-            public string URL = "";
-            public string URLName = "";
-            public List<trkseg> Segments = new List<trkseg>();
-
-            public trk(XmlNode Node)
-            {
-                foreach (XmlNode ChildNode in Node)
-                {
-                    switch (ChildNode.Name)
-                    {
-                        case "name":
-                            Name = ChildNode.InnerText;
-                            break;
-                        case "desc":
-                            Desc = ChildNode.InnerText;
-                            break;
-                        case "number":
-                            Number = ChildNode.InnerText;
-                            break;
-                        case "trkseg":
-                            trkseg Segment = new trkseg(ChildNode);
-                            Segments.Add(Segment);
-                            break;
-                        case "url":
-                            URL = ChildNode.InnerText;
-                            break;
-                        case "urlname":
-                            URLName = ChildNode.InnerText;
-                            break;
-                        case "topografix:color":
-                            break;
-                        default:
-                            throw new Exception("Unhandled for Child Object: " + ChildNode.Name);
-                    }
-                }
-            }
-        }
-
-        public class trkseg
-        {
-            public List<trkpt> TrackPoints = new List<trkpt>();
-
-            public trkseg(XmlNode Node)
-            {
-                foreach (XmlNode ChildNode in Node)
-                {
-                    switch (ChildNode.Name)
-                    {
-                        case "trkpt":
-                            trkpt TrackPoint = new trkpt(ChildNode);
-                            TrackPoints.Add(TrackPoint);
-                            break;
-                        default:
-                            throw new Exception("Unhandled for Child Object: " + ChildNode.Name);
-                    }
-                }
-            }
-        }
-
-        public class trkpt
-        {
-            public string Lat = "";
-            public string Lon = "";
-            public string Sym = "";
-            public string Ele = "0";
-            public string Time = "";
-            public string Cmt = "";
-            public string Name = "";
-            public string Desc = "";
-
-            public trkpt(XmlNode Node)
-            {
-                Lat = Node.Attributes["lat"].Value.ToString();
-                Lon = Node.Attributes["lon"].Value.ToString();
-                foreach (XmlNode ChildNode in Node)
-                {
-                    switch (ChildNode.Name)
-                    {
-                        case "sym":
-                            Sym = ChildNode.InnerText;
-                            break;
-                        case "ele":
-                            Ele = ChildNode.InnerText;
-                            break;
-                        case "time":
-                            Time = ChildNode.InnerText;
-                            break;
-                        case "cmt":
-                            Cmt = ChildNode.InnerText;
-                            break;
-                        case "name":
-                            Name = ChildNode.InnerText;
-                            break;
-                        case "desc":
-                            Desc = ChildNode.InnerText;
-                            break;
-                        default:
-                            throw new Exception("Unhandled for Child Object: " + ChildNode.Name);
-                    }
-                }
-            }
-
-            public override string ToString()
-            {
-                return "Latitude: " + Lat + " Longitude: " + Lon + " Elevation: " + Ele;
-            }
-        }
-    }
-}
\ No newline at end of file
diff --git a/PokemonGo.RocketAPI.Logic/Utils/LocationUtils.cs b/PokemonGo.RocketAPI.Logic/Utils/LocationUtils.cs
deleted file mode 100644
index d1c5cb4..0000000
--- a/PokemonGo.RocketAPI.Logic/Utils/LocationUtils.cs
+++ /dev/null
@@ -1,108 +0,0 @@
-#region
-
-using System;
-using System.Device.Location;
-
-#endregion
-
-namespace PokemonGo.RocketAPI.Logic.Utils
-{
-    public static class LocationUtils
-    {
-        public static double CalculateDistanceInMeters(double sourceLat, double sourceLng, double destLat, double destLng)
-        // from http://stackoverflow.com/questions/6366408/calculating-distance-between-two-latitude-and-longitude-geocoordinates
-        {
-            var sourceLocation = new GeoCoordinate(sourceLat, sourceLng);
-            var targetLocation = new GeoCoordinate(destLat, destLng);
-
-            return sourceLocation.GetDistanceTo(targetLocation);
-        }
-
-        public static double CalculateDistanceInMeters(GeoCoordinate sourceLocation, GeoCoordinate destinationLocation)
-        {
-            return CalculateDistanceInMeters(sourceLocation.Latitude, sourceLocation.Longitude, destinationLocation.Latitude, destinationLocation.Longitude);
-        }
-
-        public static GeoCoordinate CreateWaypoint(GeoCoordinate sourceLocation, double distanceInMeters, double bearingDegrees)
-        //from http://stackoverflow.com/a/17545955
-        {
-            var distanceKm = distanceInMeters / 1000.0;
-            var distanceRadians = distanceKm / 6371; //6371 = Earth's radius in km
-
-            var bearingRadians = ToRad(bearingDegrees);
-            var sourceLatitudeRadians = ToRad(sourceLocation.Latitude);
-            var sourceLongitudeRadians = ToRad(sourceLocation.Longitude);
-
-            var targetLatitudeRadians = Math.Asin(Math.Sin(sourceLatitudeRadians) * Math.Cos(distanceRadians)
-                                                  +
-                                                  Math.Cos(sourceLatitudeRadians) * Math.Sin(distanceRadians) *
-                                                  Math.Cos(bearingRadians));
-
-            var targetLongitudeRadians = sourceLongitudeRadians + Math.Atan2(Math.Sin(bearingRadians)
-                                                                             * Math.Sin(distanceRadians) *
-                                                                             Math.Cos(sourceLatitudeRadians),
-                Math.Cos(distanceRadians)
-                - Math.Sin(sourceLatitudeRadians) * Math.Sin(targetLatitudeRadians));
-
-            // adjust toLonRadians to be in the range -180 to +180...
-            targetLongitudeRadians = (targetLongitudeRadians + 3 * Math.PI) % (2 * Math.PI) - Math.PI;
-
-            return new GeoCoordinate(ToDegrees(targetLatitudeRadians), ToDegrees(targetLongitudeRadians));
-        }
-
-        public static GeoCoordinate CreateWaypoint(GeoCoordinate sourceLocation, double distanceInMeters, double bearingDegrees, double altitude)
-        //from http://stackoverflow.com/a/17545955
-        {
-            var distanceKm = distanceInMeters / 1000.0;
-            var distanceRadians = distanceKm / 6371; //6371 = Earth's radius in km
-
-            var bearingRadians = ToRad(bearingDegrees);
-            var sourceLatitudeRadians = ToRad(sourceLocation.Latitude);
-            var sourceLongitudeRadians = ToRad(sourceLocation.Longitude);
-
-            var targetLatitudeRadians = Math.Asin(Math.Sin(sourceLatitudeRadians) * Math.Cos(distanceRadians)
-                                                  +
-                                                  Math.Cos(sourceLatitudeRadians) * Math.Sin(distanceRadians) *
-                                                  Math.Cos(bearingRadians));
-
-            var targetLongitudeRadians = sourceLongitudeRadians + Math.Atan2(Math.Sin(bearingRadians)
-                                                                             * Math.Sin(distanceRadians) *
-                                                                             Math.Cos(sourceLatitudeRadians),
-                Math.Cos(distanceRadians)
-                - Math.Sin(sourceLatitudeRadians) * Math.Sin(targetLatitudeRadians));
-
-            // adjust toLonRadians to be in the range -180 to +180...
-            targetLongitudeRadians = (targetLongitudeRadians + 3 * Math.PI) % (2 * Math.PI) - Math.PI;
-
-            return new GeoCoordinate(ToDegrees(targetLatitudeRadians), ToDegrees(targetLongitudeRadians), altitude);
-        }
-
-        public static double DegreeBearing(GeoCoordinate sourceLocation, GeoCoordinate targetLocation)
-        // from http://stackoverflow.com/questions/2042599/direction-between-2-latitude-longitude-points-in-c-sharp
-        {
-            var dLon = ToRad(targetLocation.Longitude - sourceLocation.Longitude);
-            var dPhi = Math.Log(
-                Math.Tan(ToRad(targetLocation.Latitude) / 2 + Math.PI / 4) /
-                Math.Tan(ToRad(sourceLocation.Latitude) / 2 + Math.PI / 4));
-            if (Math.Abs(dLon) > Math.PI)
-                dLon = dLon > 0 ? -(2 * Math.PI - dLon) : 2 * Math.PI + dLon;
-            return ToBearing(Math.Atan2(dLon, dPhi));
-        }
-
-        public static double ToBearing(double radians)
-        {
-            // convert radians to degrees (as bearing: 0...360)
-            return (ToDegrees(radians) + 360) % 360;
-        }
-
-        public static double ToDegrees(double radians)
-        {
-            return radians * 180 / Math.PI;
-        }
-
-        public static double ToRad(double degrees)
-        {
-            return degrees * (Math.PI / 180);
-        }
-    }
-}
\ No newline at end of file
diff --git a/PokemonGo.RocketAPI.Logic/Utils/Statistics.cs b/PokemonGo.RocketAPI.Logic/Utils/Statistics.cs
deleted file mode 100644
index effe0b9..0000000
--- a/PokemonGo.RocketAPI.Logic/Utils/Statistics.cs
+++ /dev/null
@@ -1,187 +0,0 @@
-#region
-
-using System;
-using System.Linq;
-using System.Threading.Tasks;
-using PokemonGo.RocketAPI.GeneratedCode;
-using PokemonGo.RocketAPI.Enums;
-
-#endregion
-
-
-namespace PokemonGo.RocketAPI.Logic.Utils
-{
-    internal class Statistics
-    {
-        public static int TotalExperience;
-        public static int TotalPokemons;
-        public static int TotalItemsRemoved;
-        public static int TotalPokemonsTransfered;
-        public static int TotalStardust;
-        public static string CurrentLevelInfos;
-        public static int Currentlevel = -1;
-        public static string PlayerName;
-
-        public static DateTime InitSessionDateTime = DateTime.Now;
-        public static TimeSpan Duration = DateTime.Now - InitSessionDateTime;
-
-        public static async Task<string> _getcurrentLevelInfos(Inventory inventory)
-        {
-            var stats = await inventory.GetPlayerStats();
-            var output = string.Empty;
-            var stat = stats.FirstOrDefault();
-            if (stat != null)
-            {
-                var ep = (stat.NextLevelXp - stat.PrevLevelXp) - (stat.Experience - stat.PrevLevelXp);
-                var hours = Math.Round(ep/(TotalExperience / _getSessionRuntime()), 2);
-
-                output = $"{stat.Level} (LvLUp in {hours}hours | {stat.Experience - stat.PrevLevelXp - GetXpDiff(stat.Level)}/{stat.NextLevelXp - stat.PrevLevelXp - GetXpDiff(stat.Level)} XP)";
-                //output = $"{stat.Level} (LvLUp in {_hours}hours // EXP required: {_ep})";
-            }
-            return output;
-        }
-
-        public static string GetUsername(Client client, GetPlayerResponse profile)
-        {
-            return PlayerName = client.Settings.AuthType == AuthType.Ptc ? client.Settings.PtcUsername : profile.Profile.Username;
-        }
-
-        public static double _getSessionRuntime()
-        {
-            return (DateTime.Now - InitSessionDateTime).TotalSeconds/3600;
-        }
-
-        public static string _getSessionRuntimeInTimeFormat()
-        {
-            return (DateTime.Now - InitSessionDateTime).ToString(@"dd\.hh\:mm\:ss");
-        }
-
-        public void AddExperience(int xp)
-        {
-            TotalExperience += xp;
-        }
-
-        public void AddItemsRemoved(int count)
-        {
-            TotalItemsRemoved += count;
-        }
-
-        public void GetStardust(int stardust)
-        {
-            TotalStardust = stardust;
-        }
-
-        public void IncreasePokemons()
-        {
-            TotalPokemons += 1;
-        }
-
-        public void IncreasePokemonsTransfered()
-        {
-            TotalPokemonsTransfered += 1;
-        }
-
-        public async void UpdateConsoleTitle(Inventory _inventory)
-        {
-            CurrentLevelInfos = await _getcurrentLevelInfos(_inventory);
-            Console.Title = ToString();
-        }
-
-        public override string ToString()
-        {
-            return
-                string.Format(
-                    "{0} - Runtime {1} - Lvl: {2:0} | EXP/H: {3:0} | P/H: {4:0} | Stardust: {5:0} | Transfered: {6:0} | Items Recycled: {7:0}",
-                    PlayerName, _getSessionRuntimeInTimeFormat(), CurrentLevelInfos, TotalExperience / _getSessionRuntime(),
-                    TotalPokemons / _getSessionRuntime(), TotalStardust, TotalPokemonsTransfered, TotalItemsRemoved);
-        }
-
-        public static int GetXpDiff(int level)
-        {
-            switch (level)
-            {
-                case 1:
-                    return 0;
-                case 2:
-                    return 1000;
-                case 3:
-                    return 2000;
-                case 4:
-                    return 3000;
-                case 5:
-                    return 4000;
-                case 6:
-                    return 5000;
-                case 7:
-                    return 6000;
-                case 8:
-                    return 7000;
-                case 9:
-                    return 8000;
-                case 10:
-                    return 9000;
-                case 11:
-                    return 10000;
-                case 12:
-                    return 10000;
-                case 13:
-                    return 10000;
-                case 14:
-                    return 10000;
-                case 15:
-                    return 15000;
-                case 16:
-                    return 20000;
-                case 17:
-                    return 20000;
-                case 18:
-                    return 20000;
-                case 19:
-                    return 25000;
-                case 20:
-                    return 25000;
-                case 21:
-                    return 50000;
-                case 22:
-                    return 75000;
-                case 23:
-                    return 100000;
-                case 24:
-                    return 125000;
-                case 25:
-                    return 150000;
-                case 26:
-                    return 190000;
-                case 27:
-                    return 200000;
-                case 28:
-                    return 250000;
-                case 29:
-                    return 300000;
-                case 30:
-                    return 350000;
-                case 31:
-                    return 500000;
-                case 32:
-                    return 500000;
-                case 33:
-                    return 750000;
-                case 34:
-                    return 1000000;
-                case 35:
-                    return 1250000;
-                case 36:
-                    return 1500000;
-                case 37:
-                    return 2000000;
-                case 38:
-                    return 2500000;
-                case 39:
-                    return 1000000;
-                case 40:
-                    return 1000000;
-            }
-            return 0;
-        }
-    }
-}
\ No newline at end of file
diff --git a/PokemonGo.RocketAPI.Logic/Utils/StringUtils.cs b/PokemonGo.RocketAPI.Logic/Utils/StringUtils.cs
deleted file mode 100644
index cf8f9e0..0000000
--- a/PokemonGo.RocketAPI.Logic/Utils/StringUtils.cs
+++ /dev/null
@@ -1,28 +0,0 @@
-#region
-
-using System.Collections.Generic;
-using System.Linq;
-using PokemonGo.RocketAPI.GeneratedCode;
-
-#endregion
-
-
-namespace PokemonGo.RocketAPI.Logic.Utils
-{
-    public static class StringUtils
-    {
-        public static string GetSummedFriendlyNameOfItemAwardList(IEnumerable<FortSearchResponse.Types.ItemAward> items)
-        {
-            var enumerable = items as IList<FortSearchResponse.Types.ItemAward> ?? items.ToList();
-
-            if (!enumerable.Any())
-                return string.Empty;
-
-            return
-                enumerable.GroupBy(i => i.ItemId)
-                          .Select(kvp => new { ItemName = kvp.Key.ToString(), Amount = kvp.Sum(x => x.ItemCount) })
-                          .Select(y => $"{y.Amount} x {y.ItemName}")
-                          .Aggregate((a, b) => $"{a}, {b}");
-        }
-    }
-}
diff --git a/PokemonGo.RocketAPI.Logic/app.config b/PokemonGo.RocketAPI.Logic/app.config
deleted file mode 100644
index 8460dd4..0000000
--- a/PokemonGo.RocketAPI.Logic/app.config
+++ /dev/null
@@ -1,11 +0,0 @@
-<?xml version="1.0" encoding="utf-8"?>
-<configuration>
-  <runtime>
-    <assemblyBinding xmlns="urn:schemas-microsoft-com:asm.v1">
-      <dependentAssembly>
-        <assemblyIdentity name="Newtonsoft.Json" publicKeyToken="30ad4fe6b2a6aeed" culture="neutral" />
-        <bindingRedirect oldVersion="0.0.0.0-9.0.0.0" newVersion="9.0.0.0" />
-      </dependentAssembly>
-    </assemblyBinding>
-  </runtime>
-</configuration>
\ No newline at end of file
diff --git a/PokemonGo.RocketAPI/Client.cs b/PokemonGo.RocketAPI/Client.cs
deleted file mode 100644
index 330c0ee..0000000
--- a/PokemonGo.RocketAPI/Client.cs
+++ /dev/null
@@ -1,469 +0,0 @@
-#region
-
-using System;
-using System.IO;
-using System.Net;
-using System.Net.Http;
-using System.Threading.Tasks;
-using Google.Protobuf;
-using PokemonGo.RocketAPI.Enums;
-using PokemonGo.RocketAPI.Exceptions;
-using PokemonGo.RocketAPI.Extensions;
-using PokemonGo.RocketAPI.GeneratedCode;
-using PokemonGo.RocketAPI.Helpers;
-using PokemonGo.RocketAPI.Login;
-using static PokemonGo.RocketAPI.GeneratedCode.Response.Types;
-using PokemonGo.RocketAPI.Logging;
-
-#endregion
-
-
-namespace PokemonGo.RocketAPI
-{
-    public class Client
-    {
-        private readonly HttpClient _httpClient;
-        private string _apiUrl;
-        private AuthType _authType = AuthType.Google;
-        private Request.Types.UnknownAuth _unknownAuth;
-        Random rand = null;
-
-        public Client(ISettings settings)
-        {
-            Settings = settings;
-
-            string path = Directory.GetCurrentDirectory() + "\\Configs\\";
-            if (!Directory.Exists(path))
-            {
-                DirectoryInfo di = Directory.CreateDirectory(path);
-            }
-            string filename = "LastCoords.ini";
-            if (File.Exists(path + filename) && File.ReadAllText(path + filename).Contains(":"))
-            {
-                var latlngFromFile = File.ReadAllText(path + filename);
-                var latlng = latlngFromFile.Split(':');
-                if (latlng[0].Length != 0 && latlng[1].Length != 0)
-                {
-                    try
-                    {
-                        double temp_lat = Convert.ToDouble(latlng[0]);
-                        double temp_long = Convert.ToDouble(latlng[1]);
-
-                        if (temp_lat >= -90 && temp_lat <= 90 && temp_long >= -180 && temp_long <= 180)
-                        {
-                            SetCoordinates(Convert.ToDouble(latlng[0]), Convert.ToDouble(latlng[1]),
-                            Settings.DefaultAltitude);
-                        }
-                        else
-                        {
-                            Logger.Write("Coordinates in \"\\Configs\\Coords.ini\" file is invalid, using the default coordinates", LogLevel.Error);
-                            SetCoordinates(Settings.DefaultLatitude, Settings.DefaultLongitude, Settings.DefaultAltitude);
-                        }
-                    }
-                    catch (FormatException)
-                    {
-                        Logger.Write("Coordinates in \"\\Configs\\Coords.ini\" file is invalid, using the default coordinates", LogLevel.Error);
-                        SetCoordinates(Settings.DefaultLatitude, Settings.DefaultLongitude, Settings.DefaultAltitude);
-                    }
-                }
-                else
-                {
-                    SetCoordinates(Settings.DefaultLatitude, Settings.DefaultLongitude, Settings.DefaultAltitude);
-                }
-            }
-            else
-            {
-                Logger.Write("Missing \"\\Configs\\Coords.ini\", using default settings for coordinates and create a new one...");
-                SetCoordinates(Settings.DefaultLatitude, Settings.DefaultLongitude, Settings.DefaultAltitude);
-            }
-
-            //Setup HttpClient and create default headers
-            var handler = new HttpClientHandler
-            {
-                AutomaticDecompression = DecompressionMethods.GZip | DecompressionMethods.Deflate,
-                AllowAutoRedirect = false
-            };
-            _httpClient = new HttpClient(new RetryHandler(handler));
-            _httpClient.DefaultRequestHeaders.TryAddWithoutValidation("User-Agent", "Niantic App");
-            //"Dalvik/2.1.0 (Linux; U; Android 5.1.1; SM-G900F Build/LMY48G)");
-            _httpClient.DefaultRequestHeaders.ExpectContinue = false;
-            _httpClient.DefaultRequestHeaders.TryAddWithoutValidation("Connection", "keep-alive");
-            _httpClient.DefaultRequestHeaders.TryAddWithoutValidation("Accept", "*/*");
-            _httpClient.DefaultRequestHeaders.TryAddWithoutValidation("Content-Type",
-                "application/x-www-form-urlencoded");
-        }
-
-        public ISettings Settings { get; }
-        public string AccessToken { get; set; }
-
-        public double CurrentLat { get; private set; }
-        public double CurrentLng { get; private set; }
-        public double CurrentAltitude { get; private set; }
-
-        public async Task<CatchPokemonResponse> CatchPokemon(ulong encounterId, string spawnPointGuid, double pokemonLat,
-    double pokemonLng, MiscEnums.Item pokeball)
-        {
-
-            var customRequest = new Request.Types.CatchPokemonRequest
-            {
-                EncounterId = encounterId,
-                Pokeball = (int)pokeball,
-                SpawnPointGuid = spawnPointGuid,
-                HitPokemon = 1,
-                NormalizedReticleSize = Utils.FloatAsUlong(1.950),
-                SpinModifier = Utils.FloatAsUlong(1),
-                NormalizedHitPosition = Utils.FloatAsUlong(1)
-            };
-
-            var catchPokemonRequest = RequestBuilder.GetRequest(_unknownAuth, CurrentLat, CurrentLng, CurrentAltitude,
-                new Request.Types.Requests
-                {
-                    Type = (int)RequestType.CATCH_POKEMON,
-                    Message = customRequest.ToByteString()
-                });
-            return
-                await
-                    _httpClient.PostProtoPayload<Request, CatchPokemonResponse>($"https://{_apiUrl}/rpc", catchPokemonRequest);
-        }
-
-        public async Task DoGoogleLogin(string filename)
-        {
-            _authType = AuthType.Google;
-
-            string googleRefreshToken = string.Empty;
-            string path = Directory.GetCurrentDirectory() + "\\Configs\\";
-            if (!Directory.Exists(path))
-            {
-                DirectoryInfo di = Directory.CreateDirectory(path);
-            }
-            if (File.Exists(path + filename))
-            {
-                googleRefreshToken = File.ReadAllText(path + filename);
-            }
-
-            GoogleLogin.TokenResponseModel tokenResponse;
-            if (googleRefreshToken != string.Empty)
-            {
-                tokenResponse = await GoogleLogin.GetAccessToken(googleRefreshToken);
-                AccessToken = tokenResponse?.id_token;
-            }
-
-            if (AccessToken == null)
-            {
-                var deviceCode = await GoogleLogin.GetDeviceCode();
-                tokenResponse = await GoogleLogin.GetAccessToken(deviceCode);
-                googleRefreshToken = tokenResponse?.refresh_token;
-                Logger.Write("Refreshtoken " + tokenResponse?.refresh_token + " saved", LogLevel.Info);
-                File.WriteAllText(path + filename, googleRefreshToken);
-                AccessToken = tokenResponse?.id_token;
-            }
-
-        }
-
-        public async Task DoPtcLogin(string username, string password)
-        {
-            AccessToken = await PtcLogin.GetAccessToken(username, password);
-            _authType = AuthType.Ptc;
-        }
-
-        public async Task<EncounterResponse> EncounterPokemon(ulong encounterId, string spawnPointGuid)
-        {
-            var customRequest = new Request.Types.EncounterRequest
-            {
-                EncounterId = encounterId,
-                SpawnpointId = spawnPointGuid,
-                PlayerLatDegrees = Utils.FloatAsUlong(CurrentLat),
-                PlayerLngDegrees = Utils.FloatAsUlong(CurrentLng)
-            };
-
-            var encounterResponse = RequestBuilder.GetRequest(_unknownAuth, CurrentLat, CurrentLng, CurrentAltitude,
-                new Request.Types.Requests
-                {
-                    Type = (int)RequestType.ENCOUNTER,
-                    Message = customRequest.ToByteString()
-                });
-            return await _httpClient.PostProtoPayload<Request, EncounterResponse>($"https://{_apiUrl}/rpc", encounterResponse);
-        }
-
-        public async Task<EvolvePokemonOut> EvolvePokemon(ulong pokemonId)
-        {
-            var customRequest = new EvolvePokemon
-            {
-                PokemonId = pokemonId
-            };
-
-            var releasePokemonRequest = RequestBuilder.GetRequest(_unknownAuth, CurrentLat, CurrentLng, CurrentAltitude,
-                new Request.Types.Requests
-                {
-                    Type = (int)RequestType.EVOLVE_POKEMON,
-                    Message = customRequest.ToByteString()
-                });
-            return
-                await
-                    _httpClient.PostProtoPayload<Request, EvolvePokemonOut>($"https://{_apiUrl}/rpc", releasePokemonRequest);
-        }
-
-        public async Task<FortDetailsResponse> GetFort(string fortId, double fortLat, double fortLng)
-        {
-            var customRequest = new Request.Types.FortDetailsRequest
-            {
-                Id = ByteString.CopyFromUtf8(fortId),
-                Latitude = Utils.FloatAsUlong(fortLat),
-                Longitude = Utils.FloatAsUlong(fortLng)
-            };
-
-            var fortDetailRequest = RequestBuilder.GetRequest(_unknownAuth, CurrentLat, CurrentLng, CurrentAltitude,
-                new Request.Types.Requests
-                {
-                    Type = (int)RequestType.FORT_DETAILS,
-                    Message = customRequest.ToByteString()
-                });
-            return
-                await
-                    _httpClient.PostProtoPayload<Request, FortDetailsResponse>($"https://{_apiUrl}/rpc",
-                        fortDetailRequest);
-        }
-
-        public async Task<GetInventoryResponse> GetInventory()
-        {
-            var inventoryRequest = RequestBuilder.GetRequest(_unknownAuth, CurrentLat, CurrentLng, CurrentAltitude, RequestType.GET_INVENTORY);
-            return await _httpClient.PostProtoPayload<Request, GetInventoryResponse>($"https://{_apiUrl}/rpc", inventoryRequest);
-        }
-
-        public async Task<DownloadItemTemplatesResponse> GetItemTemplates()
-        {
-            var settingsRequest = RequestBuilder.GetRequest(_unknownAuth, CurrentLat, CurrentLng, CurrentAltitude,
-                RequestType.DOWNLOAD_ITEM_TEMPLATES);
-            return
-                await
-                    _httpClient.PostProtoPayload<Request, DownloadItemTemplatesResponse>($"https://{_apiUrl}/rpc",
-                        settingsRequest);
-        }
-
-        public async Task<GetMapObjectsResponse> GetMapObjects()
-        {
-            var customRequest = new Request.Types.MapObjectsRequest
-            {
-                CellIds =
-                    ByteString.CopyFrom(
-                        ProtoHelper.EncodeUlongList(S2Helper.GetNearbyCellIds(CurrentLng,
-                            CurrentLat))),
-                Latitude = Utils.FloatAsUlong(CurrentLat),
-                Longitude = Utils.FloatAsUlong(CurrentLng),
-                Unknown14 = ByteString.CopyFromUtf8("\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0")
-            };
-
-            var mapRequest = RequestBuilder.GetRequest(_unknownAuth, CurrentLat, CurrentLng, CurrentAltitude,
-                new Request.Types.Requests
-                {
-                    Type = (int)RequestType.GET_MAP_OBJECTS,
-                    Message = customRequest.ToByteString()
-                },
-                new Request.Types.Requests { Type = (int)RequestType.GET_HATCHED_OBJECTS },
-                new Request.Types.Requests
-                {
-                    Type = (int)RequestType.GET_INVENTORY,
-                    Message = new Request.Types.Time() {Time_ = DateTime.UtcNow.ToUnixTime()}.ToByteString()
-                },
-                new Request.Types.Requests() { Type = (int)RequestType.CHECK_AWARDED_BADGES },
-                new Request.Types.Requests()
-                {
-                    Type = (int)RequestType.DOWNLOAD_SETTINGS,
-                    Message =
-                        new Request.Types.SettingsGuid
-                        {
-                            Guid = ByteString.CopyFromUtf8("4a2e9bc330dae60e7b74fc85b98868ab4700802e")
-                        }.ToByteString()
-                });
-
-            return await _httpClient.PostProtoPayload<Request, GetMapObjectsResponse>($"https://{_apiUrl}/rpc", mapRequest);
-        }
-
-        public async Task<GetPlayerResponse> GetProfile()
-        {
-            var profileRequest = RequestBuilder.GetInitialRequest(AccessToken, _authType, CurrentLat, CurrentLng, CurrentAltitude,
-                new Request.Types.Requests { Type = (int)RequestType.GET_PLAYER });
-            return await _httpClient.PostProtoPayload<Request, GetPlayerResponse>($"https://{_apiUrl}/rpc", profileRequest);
-        }
-
-        public async Task<DownloadSettingsResponse> GetSettings()
-        {
-            var settingsRequest = RequestBuilder.GetRequest(_unknownAuth, CurrentLat, CurrentLng, CurrentAltitude,
-                RequestType.DOWNLOAD_SETTINGS);
-            return await _httpClient.PostProtoPayload<Request, DownloadSettingsResponse>($"https://{_apiUrl}/rpc", settingsRequest);
-        }
-
-        public async Task<RecycleInventoryItemResponse> RecycleItem(ItemId itemId, int amount)
-        {
-            var customRequest = new RecycleInventoryItem
-            {
-                ItemId = (ItemId)Enum.Parse(typeof(ItemId), itemId.ToString()),
-                Count = amount
-            };
-
-            var releasePokemonRequest = RequestBuilder.GetRequest(_unknownAuth, CurrentLat, CurrentLng, CurrentAltitude,
-                new Request.Types.Requests
-                {
-                    Type = (int)RequestType.RECYCLE_INVENTORY_ITEM,
-                    Message = customRequest.ToByteString()
-                });
-            return await _httpClient.PostProtoPayload<Request, RecycleInventoryItemResponse>($"https://{_apiUrl}/rpc", releasePokemonRequest);
-        }
-
-        public void SaveLatLng(double lat, double lng)
-        {
-            var latlng = lat + ":" + lng;
-            File.WriteAllText(Directory.GetCurrentDirectory() + "\\Configs\\LastCoords.ini", latlng);
-        }
-
-        public async Task<FortSearchResponse> SearchFort(string fortId, double fortLat, double fortLng)
-        {
-            var customRequest = new Request.Types.FortSearchRequest
-            {
-                Id = ByteString.CopyFromUtf8(fortId),
-                FortLatDegrees = Utils.FloatAsUlong(fortLat),
-                FortLngDegrees = Utils.FloatAsUlong(fortLng),
-                PlayerLatDegrees = Utils.FloatAsUlong(CurrentLat),
-                PlayerLngDegrees = Utils.FloatAsUlong(CurrentLng)
-            };
-
-            var fortDetailRequest = RequestBuilder.GetRequest(_unknownAuth, CurrentLat, CurrentLng, CurrentAltitude,
-                new Request.Types.Requests
-                {
-                    Type = (int)RequestType.FORT_SEARCH,
-                    Message = customRequest.ToByteString()
-                });
-            return
-                await
-                    _httpClient.PostProtoPayload<Request, FortSearchResponse>($"https://{_apiUrl}/rpc",
-                        fortDetailRequest);
-        }
-
-        /// <summary>
-        /// For GUI clients only. GUI clients don't use the DoGoogleLogin, but call the GoogleLogin class directly
-        /// </summary>
-        /// <param name="type"></param>
-        public void SetAuthType(AuthType type)
-        {
-            _authType = type;
-        }
-
-        private void CalcNoisedCoordinates(double lat, double lng, out double latNoise, out double lngNoise)
-        {
-            double mean = 0.0;// just for fun
-            double stdDev = 2.09513120352; //-> so 50% of the noised coordinates will have a maximal distance of 4 m to orginal ones
-
-            if (rand == null)
-            {
-                rand = new Random();
-            }
-            double u1 = rand.NextDouble();
-            double u2 = rand.NextDouble();
-            double u3 = rand.NextDouble();
-            double u4 = rand.NextDouble();
-
-            double randStdNormal = Math.Sqrt(-2.0 * Math.Log(u1)) * Math.Sin(2.0 * Math.PI * u2);
-            double randNormal = mean + stdDev * randStdNormal;
-            double randStdNormal2 = Math.Sqrt(-2.0 * Math.Log(u3)) * Math.Sin(2.0 * Math.PI * u4);
-            double randNormal2 = mean + stdDev * randStdNormal2;
-
-            latNoise = lat + randNormal / 100000.0;
-            lngNoise = lng + randNormal2 / 100000.0;
-        }
-
-        private void SetCoordinates(double lat, double lng, double altitude)
-        {
-            if (double.IsNaN(lat) || double.IsNaN(lng)) return;
-
-            double latNoised = 0.0;
-            double lngNoised = 0.0;
-            CalcNoisedCoordinates(lat, lng, out latNoised, out lngNoised);
-            CurrentLat = latNoised;
-            CurrentLng = lngNoised;
-            CurrentAltitude = altitude;
-            SaveLatLng(lat, lng);
-        }
-
-        public async Task SetServer()
-        {
-            var serverRequest = RequestBuilder.GetInitialRequest(AccessToken, _authType, CurrentLat, CurrentLng, CurrentAltitude,
-                RequestType.GET_PLAYER, RequestType.GET_HATCHED_OBJECTS, RequestType.GET_INVENTORY,
-                RequestType.CHECK_AWARDED_BADGES, RequestType.DOWNLOAD_SETTINGS);
-            var serverResponse = await _httpClient.PostProto(Resources.RpcUrl, serverRequest);
-
-            if (serverResponse.Auth == null)
-                throw new AccessTokenExpiredException();
-
-            _unknownAuth = new Request.Types.UnknownAuth
-            {
-                Unknown71 = serverResponse.Auth.Unknown71,
-                Timestamp = serverResponse.Auth.Timestamp,
-                Unknown73 = serverResponse.Auth.Unknown73
-            };
-
-            _apiUrl = serverResponse.ApiUrl;
-        }
-
-        public async Task RepeatAction(int repeat, Func<Task> action)
-        {
-            for (int i = 0; i < repeat; i++)
-                await action();
-        }
-
-        public async Task<TransferPokemonOut> TransferPokemon(ulong pokemonId)
-        {
-            var customRequest = new TransferPokemon
-            {
-                PokemonId = pokemonId
-            };
-
-            var releasePokemonRequest = RequestBuilder.GetRequest(_unknownAuth, CurrentLat, CurrentLng, CurrentAltitude,
-                new Request.Types.Requests
-                {
-                    Type = (int)RequestType.RELEASE_POKEMON,
-                    Message = customRequest.ToByteString()
-                });
-            return await _httpClient.PostProtoPayload<Request, TransferPokemonOut>($"https://{_apiUrl}/rpc", releasePokemonRequest);
-        }
-
-        public async Task<PlayerUpdateResponse> UpdatePlayerLocation(double lat, double lng, double alt)
-        {
-            SetCoordinates(lat, lng, alt);
-            var customRequest = new Request.Types.PlayerUpdateProto
-            {
-                Lat = Utils.FloatAsUlong(CurrentLat),
-                Lng = Utils.FloatAsUlong(CurrentLng)
-            };
-
-            var updateRequest = RequestBuilder.GetRequest(_unknownAuth, CurrentLat, CurrentLng, CurrentAltitude,
-                new Request.Types.Requests
-                {
-                    Type = (int)RequestType.PLAYER_UPDATE,
-                    Message = customRequest.ToByteString()
-                });
-            var updateResponse =
-                await
-                    _httpClient.PostProtoPayload<Request, PlayerUpdateResponse>($"https://{_apiUrl}/rpc", updateRequest);
-            return updateResponse;
-        }
-
-        public async Task<UseItemCaptureRequest> UseCaptureItem(ulong encounterId, ItemId itemId, string spawnPointGuid)
-        {
-            var customRequest = new UseItemCaptureRequest
-            {
-                EncounterId = encounterId,
-                ItemId = itemId,
-                SpawnPointGuid = spawnPointGuid
-            };
-
-            var useItemRequest = RequestBuilder.GetRequest(_unknownAuth, CurrentLat, CurrentLng, CurrentAltitude,
-                new Request.Types.Requests
-                {
-                    Type = (int)RequestType.USE_ITEM_CAPTURE,
-                    Message = customRequest.ToByteString()
-                });
-            return await _httpClient.PostProtoPayload<Request, UseItemCaptureRequest>($"https://{_apiUrl}/rpc", useItemRequest);
-        }
-
-    }
-}
diff --git a/PokemonGo.RocketAPI/Enums/AuthType.cs b/PokemonGo.RocketAPI/Enums/AuthType.cs
deleted file mode 100644
index 310163c..0000000
--- a/PokemonGo.RocketAPI/Enums/AuthType.cs
+++ /dev/null
@@ -1,8 +0,0 @@
-namespace PokemonGo.RocketAPI.Enums
-{
-    public enum AuthType
-    {
-        Google,
-        Ptc
-    }
-}
\ No newline at end of file
diff --git a/PokemonGo.RocketAPI/Enums/MiscEnums.cs b/PokemonGo.RocketAPI/Enums/MiscEnums.cs
deleted file mode 100644
index d49426a..0000000
--- a/PokemonGo.RocketAPI/Enums/MiscEnums.cs
+++ /dev/null
@@ -1,45 +0,0 @@
-namespace PokemonGo.RocketAPI.Enums
-{
-    public class MiscEnums
-    {
-        public enum FortType
-        {
-            GYM = 0,
-            CHECKPOINT = 1
-        }
-
-        public enum Item
-        {
-            ITEM_UNKNOWN = 0,
-            ITEM_POKE_BALL = 1,
-            ITEM_GREAT_BALL = 2,
-            ITEM_ULTRA_BALL = 3,
-            ITEM_MASTER_BALL = 4,
-            ITEM_POTION = 101,
-            ITEM_SUPER_POTION = 102,
-            ITEM_HYPER_POTION = 103,
-            ITEM_MAX_POTION = 104,
-            ITEM_REVIVE = 201,
-            ITEM_MAX_REVIVE = 202,
-            ITEM_LUCKY_EGG = 301,
-            ITEM_INCENSE_ORDINARY = 401,
-            ITEM_INCENSE_SPICY = 402,
-            ITEM_INCENSE_COOL = 403,
-            ITEM_INCENSE_FLORAL = 404,
-            ITEM_TROY_DISK = 501,
-            ITEM_X_ATTACK = 602,
-            ITEM_X_DEFENSE = 603,
-            ITEM_X_MIRACLE = 604,
-            ITEM_RAZZ_BERRY = 701,
-            ITEM_BLUK_BERRY = 702,
-            ITEM_NANAB_BERRY = 703,
-            ITEM_WEPAR_BERRY = 704,
-            ITEM_PINAP_BERRY = 705,
-            ITEM_SPECIAL_CAMERA = 801,
-            ITEM_INCUBATOR_BASIC_UNLIMITED = 901,
-            ITEM_INCUBATOR_BASIC = 902,
-            ITEM_POKEMON_STORAGE_UPGRADE = 1001,
-            ITEM_ITEM_STORAGE_UPGRADE = 1002
-        }
-    }
-}
\ No newline at end of file
diff --git a/PokemonGo.RocketAPI/Enums/RequestType.cs b/PokemonGo.RocketAPI/Enums/RequestType.cs
deleted file mode 100644
index 5d654a2..0000000
--- a/PokemonGo.RocketAPI/Enums/RequestType.cs
+++ /dev/null
@@ -1,77 +0,0 @@
-namespace PokemonGo.RocketAPI.Enums
-{
-    public enum RequestType
-    {
-        METHOD_UNSET = 0,
-        PLAYER_UPDATE = 1,
-        GET_PLAYER = 2,
-        GET_INVENTORY = 4,
-        DOWNLOAD_SETTINGS = 5,
-        DOWNLOAD_ITEM_TEMPLATES = 6,
-        DOWNLOAD_REMOTE_CONFIG_VERSION = 7,
-        FORT_SEARCH = 101,
-        ENCOUNTER = 102,
-        CATCH_POKEMON = 103,
-        FORT_DETAILS = 104,
-        ITEM_USE = 105,
-        GET_MAP_OBJECTS = 106,
-        FORT_DEPLOY_POKEMON = 110,
-        FORT_RECALL_POKEMON = 111,
-        RELEASE_POKEMON = 112,
-        USE_ITEM_POTION = 113,
-        USE_ITEM_CAPTURE = 114,
-        USE_ITEM_FLEE = 115,
-        USE_ITEM_REVIVE = 116,
-        TRADE_SEARCH = 117,
-        TRADE_OFFER = 118,
-        TRADE_RESPONSE = 119,
-        TRADE_RESULT = 120,
-        GET_PLAYER_PROFILE = 121,
-        GET_ITEM_PACK = 122,
-        BUY_ITEM_PACK = 123,
-        BUY_GEM_PACK = 124,
-        EVOLVE_POKEMON = 125,
-        GET_HATCHED_OBJECTS = 126,
-        ENCOUNTER_TUTORIAL_COMPLETE = 127,
-        LEVEL_UP_REWARDS = 128,
-        CHECK_AWARDED_BADGES = 129,
-        USE_ITEM_GYM = 133,
-        GET_GYM_DETAILS = 134,
-        START_GYM_BATTLE = 135,
-        ATTACK_GYM = 136,
-        RECYCLE_INVENTORY_ITEM = 137,
-        COLLECT_DAILY_BONUS = 138,
-        USE_ITEM_XP_BOOST = 139,
-        USE_ITEM_EGG_INCUBATOR = 140,
-        USE_INCENSE = 141,
-        GET_INCENSE_POKEMON = 142,
-        INCENSE_ENCOUNTER = 143,
-        ADD_FORT_MODIFIER = 144,
-        DISK_ENCOUNTER = 145,
-        COLLECT_DAILY_DEFENDER_BONUS = 146,
-        UPGRADE_POKEMON = 147,
-        SET_FAVORITE_POKEMON = 148,
-        NICKNAME_POKEMON = 149,
-        EQUIP_BADGE = 150,
-        SET_CONTACT_SETTINGS = 151,
-        GET_ASSET_DIGEST = 300,
-        GET_DOWNLOAD_URLS = 301,
-        GET_SUGGESTED_CODENAMES = 401,
-        CHECK_CODENAME_AVAILABLE = 402,
-        CLAIM_CODENAME = 403,
-        SET_AVATAR = 404,
-        SET_PLAYER_TEAM = 405,
-        MARK_TUTORIAL_COMPLETE = 406,
-        LOAD_SPAWN_POINTS = 500,
-        ECHO = 666,
-        DEBUG_UPDATE_INVENTORY = 700,
-        DEBUG_DELETE_PLAYER = 701,
-        SFIDA_REGISTRATION = 800,
-        SFIDA_ACTION_LOG = 801,
-        SFIDA_CERTIFICATION = 802,
-        SFIDA_UPDATE = 803,
-        SFIDA_ACTION = 804,
-        SFIDA_DOWSER = 805,
-        SFIDA_CAPTURE = 806
-    }
-}
\ No newline at end of file
diff --git a/PokemonGo.RocketAPI/Exceptions/AccessTokenExpiredException.cs b/PokemonGo.RocketAPI/Exceptions/AccessTokenExpiredException.cs
deleted file mode 100644
index 30e2b52..0000000
--- a/PokemonGo.RocketAPI/Exceptions/AccessTokenExpiredException.cs
+++ /dev/null
@@ -1,12 +0,0 @@
-#region
-
-using System;
-
-#endregion
-
-namespace PokemonGo.RocketAPI.Exceptions
-{
-    public class AccessTokenExpiredException : Exception
-    {
-    }
-}
\ No newline at end of file
diff --git a/PokemonGo.RocketAPI/Exceptions/AccountNotVerifiedException.cs b/PokemonGo.RocketAPI/Exceptions/AccountNotVerifiedException.cs
deleted file mode 100644
index 41faf9c..0000000
--- a/PokemonGo.RocketAPI/Exceptions/AccountNotVerifiedException.cs
+++ /dev/null
@@ -1,12 +0,0 @@
-#region
-
-using System;
-
-#endregion
-
-namespace PokemonGo.RocketAPI.Exceptions
-{
-    public class AccountNotVerifiedException : Exception
-    {
-    }
-}
\ No newline at end of file
diff --git a/PokemonGo.RocketAPI/Exceptions/InvalidResponseException.cs b/PokemonGo.RocketAPI/Exceptions/InvalidResponseException.cs
deleted file mode 100644
index 022abca..0000000
--- a/PokemonGo.RocketAPI/Exceptions/InvalidResponseException.cs
+++ /dev/null
@@ -1,12 +0,0 @@
-#region
-
-using System;
-
-#endregion
-
-namespace PokemonGo.RocketAPI.Exceptions
-{
-    public class InvalidResponseException : Exception
-    {
-    }
-}
\ No newline at end of file
diff --git a/PokemonGo.RocketAPI/Exceptions/PTCOfflineException.cs b/PokemonGo.RocketAPI/Exceptions/PTCOfflineException.cs
deleted file mode 100644
index e3100bb..0000000
--- a/PokemonGo.RocketAPI/Exceptions/PTCOfflineException.cs
+++ /dev/null
@@ -1,12 +0,0 @@
-#region
-
-using System;
-
-#endregion
-
-namespace PokemonGo.RocketAPI.Exceptions
-{
-    public class PtcOfflineException : Exception
-    {
-    }
-}
\ No newline at end of file
diff --git a/PokemonGo.RocketAPI/Extensions/DateTimeExtensions.cs b/PokemonGo.RocketAPI/Extensions/DateTimeExtensions.cs
deleted file mode 100644
index 5c5b111..0000000
--- a/PokemonGo.RocketAPI/Extensions/DateTimeExtensions.cs
+++ /dev/null
@@ -1,17 +0,0 @@
-#region
-
-using System;
-
-#endregion
-
-namespace PokemonGo.RocketAPI.Extensions
-{
-    public static class DateTimeExtensions
-    {
-        public static long ToUnixTime(this DateTime date)
-        {
-            var epoch = new DateTime(1970, 1, 1, 0, 0, 0, DateTimeKind.Utc);
-            return Convert.ToInt64((date - epoch).TotalMilliseconds);
-        }
-    }
-}
\ No newline at end of file
diff --git a/PokemonGo.RocketAPI/Extensions/HttpClientExtensions.cs b/PokemonGo.RocketAPI/Extensions/HttpClientExtensions.cs
deleted file mode 100644
index 8d1eff6..0000000
--- a/PokemonGo.RocketAPI/Extensions/HttpClientExtensions.cs
+++ /dev/null
@@ -1,51 +0,0 @@
-#region
-
-using System.Net.Http;
-using System.Threading.Tasks;
-using Google.Protobuf;
-using PokemonGo.RocketAPI.Exceptions;
-using PokemonGo.RocketAPI.GeneratedCode;
-using PokemonGo.RocketAPI.Logging;
-
-#endregion
-
-namespace PokemonGo.RocketAPI.Extensions
-{
-    public static class HttpClientExtensions
-    {
-        public static async Task<Response> PostProto<TRequest>(this HttpClient client, string url, TRequest request)
-            where TRequest : IMessage<TRequest>
-        {
-            //Encode payload and put in envelop, then send
-            var data = request.ToByteString();
-            var result = await client.PostAsync(url, new ByteArrayContent(data.ToByteArray()));
-
-            //Decode message
-            var responseData = await result.Content.ReadAsByteArrayAsync();
-            var codedStream = new CodedInputStream(responseData);
-            var decodedResponse = new Response();
-            decodedResponse.MergeFrom(codedStream);
-
-            return decodedResponse;
-        }
-
-        public static async Task<TResponsePayload> PostProtoPayload<TRequest, TResponsePayload>(this HttpClient client,
-            string url, TRequest request) where TRequest : IMessage<TRequest>
-            where TResponsePayload : IMessage<TResponsePayload>, new()
-        {
-            //Logger.Write($"Requesting {typeof(TResponsePayload).Name}", LogLevel.Debug);
-            var response = await PostProto(client, url, request);
-
-            if (response.Payload.Count == 0)
-                throw new InvalidResponseException();
-
-            //Decode payload
-            //todo: multi-payload support
-            var payload = response.Payload[0];
-            var parsedPayload = new TResponsePayload();
-            parsedPayload.MergeFrom(payload);
-
-            return parsedPayload;
-        }
-    }
-}
\ No newline at end of file
diff --git a/PokemonGo.RocketAPI/GeneratedCode/AllEnum.cs b/PokemonGo.RocketAPI/GeneratedCode/AllEnum.cs
deleted file mode 100644
index 946c888..0000000
--- a/PokemonGo.RocketAPI/GeneratedCode/AllEnum.cs
+++ /dev/null
@@ -1,1111 +0,0 @@
-// Generated by the protocol buffer compiler.  DO NOT EDIT!
-// source: AllEnum.proto
-#pragma warning disable 1591, 0612, 3021
-#region Designer generated code
-
-using pb = global::Google.Protobuf;
-using pbc = global::Google.Protobuf.Collections;
-using pbr = global::Google.Protobuf.Reflection;
-using scg = global::System.Collections.Generic;
-namespace PokemonGo.RocketAPI.GeneratedCode {
-
-  /// <summary>Holder for reflection information generated from AllEnum.proto</summary>
-  public static partial class AllEnumReflection {
-
-    #region Descriptor
-    /// <summary>File descriptor for AllEnum.proto</summary>
-    public static pbr::FileDescriptor Descriptor {
-      get { return descriptor; }
-    }
-    private static pbr::FileDescriptor descriptor;
-
-    static AllEnumReflection() {
-      byte[] descriptorData = global::System.Convert.FromBase64String(
-          string.Concat(
-            "Cg1BbGxFbnVtLnByb3RvEgdBbGxFbnVtKjYKDFJwY0RpcmVjdGlvbhILCgdV",
-            "TktOT1dOEAASDAoIUkVTUE9OU0UQARILCgdSRVFVRVNUEAIqNwoJVGVhbUNv",
-            "bG9yEgsKB05FVVRSQUwQABIICgRCTFVFEAESBwoDUkVEEAISCgoGWUVMTE9X",
-            "EAMqwwwKDVJlcXVlc3RNZXRob2QSEAoMTUVUSE9EX1VOU0VUEAASEQoNUExB",
-            "WUVSX1VQREFURRABEg4KCkdFVF9QTEFZRVIQAhIRCg1HRVRfSU5WRU5UT1JZ",
-            "EAQSFQoRRE9XTkxPQURfU0VUVElOR1MQBRIbChdET1dOTE9BRF9JVEVNX1RF",
-            "TVBMQVRFUxAGEiIKHkRPV05MT0FEX1JFTU9URV9DT05GSUdfVkVSU0lPThAH",
-            "Eg8KC0ZPUlRfU0VBUkNIEGUSDQoJRU5DT1VOVEVSEGYSEQoNQ0FUQ0hfUE9L",
-            "RU1PThBnEhAKDEZPUlRfREVUQUlMUxBoEgwKCElURU1fVVNFEGkSEwoPR0VU",
-            "X01BUF9PQkpFQ1RTEGoSFwoTRk9SVF9ERVBMT1lfUE9LRU1PThBuEhcKE0ZP",
-            "UlRfUkVDQUxMX1BPS0VNT04QbxITCg9SRUxFQVNFX1BPS0VNT04QcBITCg9V",
-            "U0VfSVRFTV9QT1RJT04QcRIUChBVU0VfSVRFTV9DQVBUVVJFEHISEQoNVVNF",
-            "X0lURU1fRkxFRRBzEhMKD1VTRV9JVEVNX1JFVklWRRB0EhAKDFRSQURFX1NF",
-            "QVJDSBB1Eg8KC1RSQURFX09GRkVSEHYSEgoOVFJBREVfUkVTUE9OU0UQdxIQ",
-            "CgxUUkFERV9SRVNVTFQQeBIWChJHRVRfUExBWUVSX1BST0ZJTEUQeRIRCg1H",
-            "RVRfSVRFTV9QQUNLEHoSEQoNQlVZX0lURU1fUEFDSxB7EhAKDEJVWV9HRU1f",
-            "UEFDSxB8EhIKDkVWT0xWRV9QT0tFTU9OEH0SFAoQR0VUX0hBVENIRURfRUdH",
-            "UxB+Eh8KG0VOQ09VTlRFUl9UVVRPUklBTF9DT01QTEVURRB/EhUKEExFVkVM",
-            "X1VQX1JFV0FSRFMQgAESGQoUQ0hFQ0tfQVdBUkRFRF9CQURHRVMQgQESEQoM",
-            "VVNFX0lURU1fR1lNEIUBEhQKD0dFVF9HWU1fREVUQUlMUxCGARIVChBTVEFS",
-            "VF9HWU1fQkFUVExFEIcBEg8KCkFUVEFDS19HWU0QiAESGwoWUkVDWUNMRV9J",
-            "TlZFTlRPUllfSVRFTRCJARIYChNDT0xMRUNUX0RBSUxZX0JPTlVTEIoBEhYK",
-            "EVVTRV9JVEVNX1hQX0JPT1NUEIsBEhsKFlVTRV9JVEVNX0VHR19JTkNVQkFU",
-            "T1IQjAESEAoLVVNFX0lOQ0VOU0UQjQESGAoTR0VUX0lOQ0VOU0VfUE9LRU1P",
-            "ThCOARIWChFJTkNFTlNFX0VOQ09VTlRFUhCPARIWChFBRERfRk9SVF9NT0RJ",
-            "RklFUhCQARITCg5ESVNLX0VOQ09VTlRFUhCRARIhChxDT0xMRUNUX0RBSUxZ",
-            "X0RFRkVOREVSX0JPTlVTEJIBEhQKD1VQR1JBREVfUE9LRU1PThCTARIZChRT",
-            "RVRfRkFWT1JJVEVfUE9LRU1PThCUARIVChBOSUNLTkFNRV9QT0tFTU9OEJUB",
-            "EhAKC0VRVUlQX0JBREdFEJYBEhkKFFNFVF9DT05UQUNUX1NFVFRJTkdTEJcB",
-            "EhUKEEdFVF9BU1NFVF9ESUdFU1QQrAISFgoRR0VUX0RPV05MT0FEX1VSTFMQ",
-            "rQISHAoXR0VUX1NVR0dFU1RFRF9DT0RFTkFNRVMQkQMSHQoYQ0hFQ0tfQ09E",
-            "RU5BTUVfQVZBSUxBQkxFEJIDEhMKDkNMQUlNX0NPREVOQU1FEJMDEg8KClNF",
-            "VF9BVkFUQVIQlAMSFAoPU0VUX1BMQVlFUl9URUFNEJUDEhsKFk1BUktfVFVU",
-            "T1JJQUxfQ09NUExFVEUQlgMSFgoRTE9BRF9TUEFXTl9QT0lOVFMQ9AMSCQoE",
-            "RUNITxCaBRIbChZERUJVR19VUERBVEVfSU5WRU5UT1JZELwFEhgKE0RFQlVH",
-            "X0RFTEVURV9QTEFZRVIQvQUSFwoSU0ZJREFfUkVHSVNUUkFUSU9OEKAGEhUK",
-            "EFNGSURBX0FDVElPTl9MT0cQoQYSGAoTU0ZJREFfQ0VSVElGSUNBVElPThCi",
-            "BhIRCgxTRklEQV9VUERBVEUQowYSEQoMU0ZJREFfQUNUSU9OEKQGEhEKDFNG",
-            "SURBX0RPV1NFUhClBhISCg1TRklEQV9DQVBUVVJFEKYGKs4XCgtQb2tlbW9u",
-            "TW92ZRIOCgpNT1ZFX1VOU0VUEAASEQoNVEhVTkRFUl9TSE9DSxABEhAKDFFV",
-            "SUNLX0FUVEFDSxACEgsKB1NDUkFUQ0gQAxIJCgVFTUJFUhAEEg0KCVZJTkVf",
-            "V0hJUBAFEgoKBlRBQ0tMRRAGEg4KClJBWk9SX0xFQUYQBxINCglUQUtFX0RP",
-            "V04QCBINCglXQVRFUl9HVU4QCRIICgRCSVRFEAoSCQoFUE9VTkQQCxIPCgtE",
-            "T1VCTEVfU0xBUBAMEggKBFdSQVAQDRIOCgpIWVBFUl9CRUFNEA4SCAoETElD",
-            "SxAPEg4KCkRBUktfUFVMU0UQEBIICgRTTU9HEBESCgoGU0xVREdFEBISDgoK",
-            "TUVUQUxfQ0xBVxATEg0KCVZJQ0VfR1JJUBAUEg8KC0ZMQU1FX1dIRUVMEBUS",
-            "DAoITUVHQUhPUk4QFhIPCgtXSU5HX0FUVEFDSxAXEhAKDEZMQU1FVEhST1dF",
-            "UhAYEhAKDFNVQ0tFUl9QVU5DSBAZEgcKA0RJRxAaEgwKCExPV19LSUNLEBsS",
-            "DgoKQ1JPU1NfQ0hPUBAcEg4KClBTWUNIT19DVVQQHRILCgdQU1lCRUFNEB4S",
-            "DgoKRUFSVEhRVUFLRRAfEg4KClNUT05FX0VER0UQIBINCglJQ0VfUFVOQ0gQ",
-            "IRIPCgtIRUFSVF9TVEFNUBAiEg0KCURJU0NIQVJHRRAjEhAKDEZMQVNIX0NB",
-            "Tk5PThAkEggKBFBFQ0sQJRIOCgpEUklMTF9QRUNLECYSDAoISUNFX0JFQU0Q",
-            "JxIMCghCTElaWkFSRBAoEg0KCUFJUl9TTEFTSBApEg0KCUhFQVRfV0FWRRAq",
-            "Eg0KCVRXSU5FRURMRRArEg4KClBPSVNPTl9KQUIQLBIOCgpBRVJJQUxfQUNF",
-            "EC0SDQoJRFJJTExfUlVOEC4SEgoOUEVUQUxfQkxJWlpBUkQQLxIOCgpNRUdB",
-            "X0RSQUlOEDASDAoIQlVHX0JVWloQMRIPCgtQT0lTT05fRkFORxAyEg8KC05J",
-            "R0hUX1NMQVNIEDMSCQoFU0xBU0gQNBIPCgtCVUJCTEVfQkVBTRA1Eg4KClNV",
-            "Qk1JU1NJT04QNhIPCgtLQVJBVEVfQ0hPUBA3Eg0KCUxPV19TV0VFUBA4EgwK",
-            "CEFRVUFfSkVUEDkSDQoJQVFVQV9UQUlMEDoSDQoJU0VFRF9CT01CEDsSDAoI",
-            "UFNZU0hPQ0sQPBIOCgpST0NLX1RIUk9XED0SEQoNQU5DSUVOVF9QT1dFUhA+",
-            "Eg0KCVJPQ0tfVE9NQhA/Eg4KClJPQ0tfU0xJREUQQBINCglQT1dFUl9HRU0Q",
-            "QRIQCgxTSEFET1dfU05FQUsQQhIQCgxTSEFET1dfUFVOQ0gQQxIPCgtTSEFE",
-            "T1dfQ0xBVxBEEhAKDE9NSU5PVVNfV0lORBBFEg8KC1NIQURPV19CQUxMEEYS",
-            "EAoMQlVMTEVUX1BVTkNIEEcSDwoLTUFHTkVUX0JPTUIQSBIOCgpTVEVFTF9X",
-            "SU5HEEkSDQoJSVJPTl9IRUFEEEoSFAoQUEFSQUJPTElDX0NIQVJHRRBLEgkK",
-            "BVNQQVJLEEwSEQoNVEhVTkRFUl9QVU5DSBBNEgsKB1RIVU5ERVIQThIPCgtU",
-            "SFVOREVSQk9MVBBPEgsKB1RXSVNURVIQUBIRCg1EUkFHT05fQlJFQVRIEFES",
-            "EAoMRFJBR09OX1BVTFNFEFISDwoLRFJBR09OX0NMQVcQUxITCg9ESVNBUk1J",
-            "TkdfVk9JQ0UQVBIRCg1EUkFJTklOR19LSVNTEFUSEgoOREFaWkxJTkdfR0xF",
-            "QU0QVhINCglNT09OQkxBU1QQVxIOCgpQTEFZX1JPVUdIEFgSEAoMQ1JPU1Nf",
-            "UE9JU09OEFkSDwoLU0xVREdFX0JPTUIQWhIPCgtTTFVER0VfV0FWRRBbEg0K",
-            "CUdVTktfU0hPVBBcEgwKCE1VRF9TSE9UEF0SDQoJQk9ORV9DTFVCEF4SDAoI",
-            "QlVMTERPWkUQXxIMCghNVURfQk9NQhBgEg8KC0ZVUllfQ1VUVEVSEGESDAoI",
-            "QlVHX0JJVEUQYhIPCgtTSUdOQUxfQkVBTRBjEg0KCVhfU0NJU1NPUhBkEhAK",
-            "DEZMQU1FX0NIQVJHRRBlEg8KC0ZMQU1FX0JVUlNUEGYSDgoKRklSRV9CTEFT",
-            "VBBnEgkKBUJSSU5FEGgSDwoLV0FURVJfUFVMU0UQaRIJCgVTQ0FMRBBqEg4K",
-            "CkhZRFJPX1BVTVAQaxILCgdQU1lDSElDEGwSDQoJUFNZU1RSSUtFEG0SDQoJ",
-            "SUNFX1NIQVJEEG4SDAoISUNZX1dJTkQQbxIQCgxGUk9TVF9CUkVBVEgQcBIK",
-            "CgZBQlNPUkIQcRIOCgpHSUdBX0RSQUlOEHISDgoKRklSRV9QVU5DSBBzEg4K",
-            "ClNPTEFSX0JFQU0QdBIOCgpMRUFGX0JMQURFEHUSDgoKUE9XRVJfV0hJUBB2",
-            "EgoKBlNQTEFTSBB3EggKBEFDSUQQeBIOCgpBSVJfQ1VUVEVSEHkSDQoJSFVS",
-            "UklDQU5FEHoSDwoLQlJJQ0tfQlJFQUsQexIHCgNDVVQQfBIJCgVTV0lGVBB9",
-            "Eg8KC0hPUk5fQVRUQUNLEH4SCQoFU1RPTVAQfxINCghIRUFEQlVUVBCAARIP",
-            "CgpIWVBFUl9GQU5HEIEBEgkKBFNMQU0QggESDgoJQk9EWV9TTEFNEIMBEgkK",
-            "BFJFU1QQhAESDQoIU1RSVUdHTEUQhQESFAoPU0NBTERfQkxBU1RPSVNFEIYB",
-            "EhkKFEhZRFJPX1BVTVBfQkxBU1RPSVNFEIcBEg8KCldSQVBfR1JFRU4QiAES",
-            "DgoJV1JBUF9QSU5LEIkBEhUKEEZVUllfQ1VUVEVSX0ZBU1QQyAESEgoNQlVH",
-            "X0JJVEVfRkFTVBDJARIOCglCSVRFX0ZBU1QQygESFgoRU1VDS0VSX1BVTkNI",
-            "X0ZBU1QQywESFwoSRFJBR09OX0JSRUFUSF9GQVNUEMwBEhcKElRIVU5ERVJf",
-            "U0hPQ0tfRkFTVBDNARIPCgpTUEFSS19GQVNUEM4BEhIKDUxPV19LSUNLX0ZB",
-            "U1QQzwESFQoQS0FSQVRFX0NIT1BfRkFTVBDQARIPCgpFTUJFUl9GQVNUENEB",
-            "EhUKEFdJTkdfQVRUQUNLX0ZBU1QQ0gESDgoJUEVDS19GQVNUENMBEg4KCUxJ",
-            "Q0tfRkFTVBDUARIVChBTSEFET1dfQ0xBV19GQVNUENUBEhMKDlZJTkVfV0hJ",
-            "UF9GQVNUENYBEhQKD1JBWk9SX0xFQUZfRkFTVBDXARISCg1NVURfU0hPVF9G",
-            "QVNUENgBEhMKDklDRV9TSEFSRF9GQVNUENkBEhYKEUZST1NUX0JSRUFUSF9G",
-            "QVNUENoBEhYKEVFVSUNLX0FUVEFDS19GQVNUENsBEhEKDFNDUkFUQ0hfRkFT",
-            "VBDcARIQCgtUQUNLTEVfRkFTVBDdARIPCgpQT1VORF9GQVNUEN4BEg0KCENV",
-            "VF9GQVNUEN8BEhQKD1BPSVNPTl9KQUJfRkFTVBDgARIOCglBQ0lEX0ZBU1QQ",
-            "4QESFAoPUFNZQ0hPX0NVVF9GQVNUEOIBEhQKD1JPQ0tfVEhST1dfRkFTVBDj",
-            "ARIUCg9NRVRBTF9DTEFXX0ZBU1QQ5AESFgoRQlVMTEVUX1BVTkNIX0ZBU1QQ",
-            "5QESEwoOV0FURVJfR1VOX0ZBU1QQ5gESEAoLU1BMQVNIX0ZBU1QQ5wESHQoY",
-            "V0FURVJfR1VOX0ZBU1RfQkxBU1RPSVNFEOgBEhIKDU1VRF9TTEFQX0ZBU1QQ",
-            "6QESFgoRWkVOX0hFQURCVVRUX0ZBU1QQ6gESEwoOQ09ORlVTSU9OX0ZBU1QQ",
-            "6wESFgoRUE9JU09OX1NUSU5HX0ZBU1QQ7AESEAoLQlVCQkxFX0ZBU1QQ7QES",
-            "FgoRRkVJTlRfQVRUQUNLX0ZBU1QQ7gESFAoPU1RFRUxfV0lOR19GQVNUEO8B",
-            "EhMKDkZJUkVfRkFOR19GQVNUEPABEhQKD1JPQ0tfU01BU0hfRkFTVBDxASrH",
-            "BQoGSXRlbUlkEhAKDElURU1fVU5LTk9XThAAEhIKDklURU1fUE9LRV9CQUxM",
-            "EAESEwoPSVRFTV9HUkVBVF9CQUxMEAISEwoPSVRFTV9VTFRSQV9CQUxMEAMS",
-            "FAoQSVRFTV9NQVNURVJfQkFMTBAEEg8KC0lURU1fUE9USU9OEGUSFQoRSVRF",
-            "TV9TVVBFUl9QT1RJT04QZhIVChFJVEVNX0hZUEVSX1BPVElPThBnEhMKD0lU",
-            "RU1fTUFYX1BPVElPThBoEhAKC0lURU1fUkVWSVZFEMkBEhQKD0lURU1fTUFY",
-            "X1JFVklWRRDKARITCg5JVEVNX0xVQ0tZX0VHRxCtAhIaChVJVEVNX0lOQ0VO",
-            "U0VfT1JESU5BUlkQkQMSFwoSSVRFTV9JTkNFTlNFX1NQSUNZEJIDEhYKEUlU",
-            "RU1fSU5DRU5TRV9DT09MEJMDEhgKE0lURU1fSU5DRU5TRV9GTE9SQUwQlAMS",
-            "EwoOSVRFTV9UUk9ZX0RJU0sQ9QMSEgoNSVRFTV9YX0FUVEFDSxDaBBITCg5J",
-            "VEVNX1hfREVGRU5TRRDbBBITCg5JVEVNX1hfTUlSQUNMRRDcBBIUCg9JVEVN",
-            "X1JBWlpfQkVSUlkQvQUSFAoPSVRFTV9CTFVLX0JFUlJZEL4FEhUKEElURU1f",
-            "TkFOQUJfQkVSUlkQvwUSFQoQSVRFTV9XRVBBUl9CRVJSWRDABRIVChBJVEVN",
-            "X1BJTkFQX0JFUlJZEMEFEhgKE0lURU1fU1BFQ0lBTF9DQU1FUkEQoQYSIwoe",
-            "SVRFTV9JTkNVQkFUT1JfQkFTSUNfVU5MSU1JVEVEEIUHEhkKFElURU1fSU5D",
-            "VUJBVE9SX0JBU0lDEIYHEiEKHElURU1fUE9LRU1PTl9TVE9SQUdFX1VQR1JB",
-            "REUQ6QcSHgoZSVRFTV9JVEVNX1NUT1JBR0VfVVBHUkFERRDqBypiChRJbnZl",
-            "bnRvcnlVcGdyYWRlVHlwZRIRCg1VUEdSQURFX1VOU0VUEAASGQoVSU5DUkVB",
-            "U0VfSVRFTV9TVE9SQUdFEAESHAoYSU5DUkVBU0VfUE9LRU1PTl9TVE9SQUdF",
-            "EAIqPwoQRWdnSW5jdWJhdG9yVHlwZRITCg9JTkNVQkFUT1JfVU5TRVQQABIW",
-            "ChJJTkNVQkFUT1JfRElTVEFOQ0UQASrdDAoPUG9rZW1vbkZhbWlseUlkEhAK",
-            "DEZBTUlMWV9VTlNFVBAAEhQKEEZBTUlMWV9CVUxCQVNBVVIQARIVChFGQU1J",
-            "TFlfQ0hBUk1BTkRFUhAEEhMKD0ZBTUlMWV9TUVVJUlRMRRAHEhMKD0ZBTUlM",
-            "WV9DQVRFUlBJRRAKEhEKDUZBTUlMWV9XRUVETEUQDRIRCg1GQU1JTFlfUElE",
-            "R0VZEBASEgoORkFNSUxZX1JBVFRBVEEQExISCg5GQU1JTFlfU1BFQVJPVxAV",
-            "EhAKDEZBTUlMWV9FS0FOUxAXEhIKDkZBTUlMWV9QSUtBQ0hVEBkSFAoQRkFN",
-            "SUxZX1NBTkRTSFJFVxAbEhIKDkZBTUlMWV9OSURPUkFOEB0SEwoPRkFNSUxZ",
-            "X05JRE9SQU4yECASEwoPRkFNSUxZX0NMRUZBSVJZECMSEQoNRkFNSUxZX1ZV",
-            "TFBJWBAlEhUKEUZBTUlMWV9KSUdHTFlQVUZGECcSEAoMRkFNSUxZX1pVQkFU",
-            "ECkSEQoNRkFNSUxZX09ERElTSBArEhAKDEZBTUlMWV9QQVJBUxAuEhIKDkZB",
-            "TUlMWV9WRU5PTkFUEDASEgoORkFNSUxZX0RJR0xFVFQQMhIRCg1GQU1JTFlf",
-            "TUVPV1RIEDQSEgoORkFNSUxZX1BTWURVQ0sQNhIRCg1GQU1JTFlfTUFOS0VZ",
-            "EDgSFAoQRkFNSUxZX0dST1dMSVRIRRA6EhIKDkZBTUlMWV9QT0xJV0FHEDwS",
-            "DwoLRkFNSUxZX0FCUkEQPxIRCg1GQU1JTFlfTUFDSE9QEEISFQoRRkFNSUxZ",
-            "X0JFTExTUFJPVVQQRRIUChBGQU1JTFlfVEVOVEFDT09MEEgSEgoORkFNSUxZ",
-            "X0dFT0RVREUQShIRCg1GQU1JTFlfUE9OWVRBEE0SEwoPRkFNSUxZX1NMT1dQ",
-            "T0tFEE8SFAoQRkFNSUxZX01BR05FTUlURRBREhQKEEZBTUlMWV9GQVJGRVRD",
-            "SEQQUxIQCgxGQU1JTFlfRE9EVU8QVBIPCgtGQU1JTFlfU0VFTBBWEhEKDUZB",
-            "TUlMWV9HUklNRVIQWBITCg9GQU1JTFlfU0hFTExERVIQWhIRCg1GQU1JTFlf",
-            "R0FTVExZEFwSDwoLRkFNSUxZX09OSVgQXxISCg5GQU1JTFlfRFJPV1pFRRBg",
-            "EhEKDUZBTUlMWV9LUkFCQlkQYhISCg5GQU1JTFlfVk9MVE9SQhBkEhQKEEZB",
-            "TUlMWV9FWEVHR0NVVEUQZhIRCg1GQU1JTFlfQ1VCT05FEGgSFAoQRkFNSUxZ",
-            "X0hJVE1PTkxFRRBqEhUKEUZBTUlMWV9ISVRNT05DSEFOEGsSFAoQRkFNSUxZ",
-            "X0xJQ0tJVFVORxBsEhIKDkZBTUlMWV9LT0ZGSU5HEG0SEgoORkFNSUxZX1JI",
-            "WUhPUk4QbxISCg5GQU1JTFlfQ0hBTlNFWRBxEhIKDkZBTUlMWV9UQU5HRUxB",
-            "EHISFQoRRkFNSUxZX0tBTkdBU0tIQU4QcxIRCg1GQU1JTFlfSE9SU0VBEHQS",
-            "EgoORkFNSUxZX0dPTERFRU4QdhIRCg1GQU1JTFlfU1RBUllVEHgSEgoORkFN",
-            "SUxZX01SX01JTUUQehISCg5GQU1JTFlfU0NZVEhFUhB7Eg8KC0ZBTUlMWV9K",
-            "WU5YEHwSFQoRRkFNSUxZX0VMRUNUQUJVWloQfRIRCg1GQU1JTFlfTUFHTUFS",
-            "EH4SEQoNRkFNSUxZX1BJTlNJUhB/EhIKDUZBTUlMWV9UQVVST1MQgAESFAoP",
-            "RkFNSUxZX01BR0lLQVJQEIEBEhIKDUZBTUlMWV9MQVBSQVMQgwESEQoMRkFN",
-            "SUxZX0RJVFRPEIQBEhEKDEZBTUlMWV9FRVZFRRCFARITCg5GQU1JTFlfUE9S",
-            "WUdPThCJARITCg5GQU1JTFlfT01BTllURRCKARISCg1GQU1JTFlfS0FCVVRP",
-            "EIwBEhYKEUZBTUlMWV9BRVJPREFDVFlMEI4BEhMKDkZBTUlMWV9TTk9STEFY",
-            "EI8BEhQKD0ZBTUlMWV9BUlRJQ1VOTxCQARISCg1GQU1JTFlfWkFQRE9TEJEB",
-            "EhMKDkZBTUlMWV9NT0xUUkVTEJIBEhMKDkZBTUlMWV9EUkFUSU5JEJMBEhIK",
-            "DUZBTUlMWV9NRVdUV08QlgESDwoKRkFNSUxZX01FVxCXASpFChBNYXBPYmpl",
-            "Y3RzU3RhdHVzEhAKDFVOU0VUX1NUQVRVUxAAEgsKB1NVQ0NFU1MQARISCg5M",
-            "T0NBVElPTl9VTlNFVBACKiMKCEZvcnRUeXBlEgcKA0dZTRAAEg4KCkNIRUNL",
-            "UE9JTlQQASqUEAoJUG9rZW1vbklkEg0KCU1JU1NJTkdOTxAAEg0KCUJVTEJB",
-            "U0FVUhABEgsKB0lWWVNBVVIQAhIMCghWRU5VU0FVUhADEg4KCkNIQVJNQU5E",
-            "RVIQBBIOCgpDSEFSTUVMRU9OEAUSDQoJQ0hBUklaQVJEEAYSDAoIU1FVSVJU",
-            "TEUQBxINCglXQVJUT1JUTEUQCBINCglCTEFTVE9JU0UQCRIMCghDQVRFUlBJ",
-            "RRAKEgsKB01FVEFQT0QQCxIOCgpCVVRURVJGUkVFEAwSCgoGV0VFRExFEA0S",
-            "CgoGS0FLVU5BEA4SDAoIQkVFRFJJTEwQDxIKCgZQSURHRVkQEBINCglQSURH",
-            "RU9UVE8QERILCgdQSURHRU9UEBISCwoHUkFUVEFUQRATEgwKCFJBVElDQVRF",
-            "EBQSCwoHU1BFQVJPVxAVEgoKBkZFQVJPVxAWEgkKBUVLQU5TEBcSCQoFQVJC",
-            "T0sQGBILCgdQSUtBQ0hVEBkSCgoGUkFJQ0hVEBoSDQoJU0FORFNIUkVXEBsS",
-            "DAoIU0FORExBU0gQHBISCg5OSURPUkFOX0ZFTUFMRRAdEgwKCE5JRE9SSU5B",
-            "EB4SDQoJTklET1FVRUVOEB8SEAoMTklET1JBTl9NQUxFECASDAoITklET1JJ",
-            "Tk8QIRIMCghOSURPS0lORxAiEgwKCENMRUZBSVJZECMSDAoIQ0xFRkFCTEUQ",
-            "JBIKCgZWVUxQSVgQJRINCglOSU5FVEFMRVMQJhIOCgpKSUdHTFlQVUZGECcS",
-            "DgoKV0lHR0xZVFVGRhAoEgkKBVpVQkFUECkSCgoGR09MQkFUECoSCgoGT0RE",
-            "SVNIECsSCQoFR0xPT00QLBINCglWSUxFUExVTUUQLRIJCgVQQVJBUxAuEgwK",
-            "CFBBUkFTRUNUEC8SCwoHVkVOT05BVBAwEgwKCFZFTk9NT1RIEDESCwoHRElH",
-            "TEVUVBAyEgsKB0RVR1RSSU8QMxIKCgZNRU9XVEgQNBILCgdQRVJTSUFOEDUS",
-            "CwoHUFNZRFVDSxA2EgsKB0dPTERVQ0sQNxIKCgZNQU5LRVkQOBIMCghQUklN",
-            "RUFQRRA5Eg0KCUdST1dMSVRIRRA6EgwKCEFSQ0FOSU5FEDsSCwoHUE9MSVdB",
-            "RxA8Eg0KCVBPTElXSElSTBA9Eg0KCVBPTElXUkFUSBA+EggKBEFCUkEQPxIL",
-            "CgdLQURBQlJBEEASDQoJQUxBS0hBWkFNEEESCgoGTUFDSE9QEEISCwoHTUFD",
-            "SE9LRRBDEgsKB01BQ0hBTVAQRBIOCgpCRUxMU1BST1VUEEUSDgoKV0VFUElO",
-            "QkVMTBBGEg8KC1ZJQ1RSRUVCRUxMEEcSDQoJVEVOVEFDT09MEEgSDgoKVEVO",
-            "VEFDUlVFTBBJEgsKB0dFT0RVREUQShIMCghHUkFWRUxFUhBLEgkKBUdPTEVN",
-            "EEwSCgoGUE9OWVRBEE0SDAoIUkFQSURBU0gQThIMCghTTE9XUE9LRRBPEgsK",
-            "B1NMT1dCUk8QUBINCglNQUdORU1JVEUQURIMCghNQUdORVRPThBSEg0KCUZB",
-            "UkZFVENIRBBTEgkKBURPRFVPEFQSCgoGRE9EUklPEFUSCAoEU0VFTBBWEgsK",
-            "B0RFV0dPTkcQVxIKCgZHUklNRVIQWBIHCgNNVUsQWRIMCghTSEVMTERFUhBa",
-            "EgwKCENMT1lTVEVSEFsSCgoGR0FTVExZEFwSCwoHSEFVTlRFUhBdEgoKBkdF",
-            "TkdBUhBeEggKBE9OSVgQXxILCgdEUk9XWkVFEGASCQoFSFlQTk8QYRIKCgZL",
-            "UkFCQlkQYhILCgdLSU5HTEVSEGMSCwoHVk9MVE9SQhBkEg0KCUVMRUNUUk9E",
-            "RRBlEg0KCUVYRUdHQ1VURRBmEg0KCUVYRUdHVVRPUhBnEgoKBkNVQk9ORRBo",
-            "EgsKB01BUk9XQUsQaRINCglISVRNT05MRUUQahIOCgpISVRNT05DSEFOEGsS",
-            "DQoJTElDS0lUVU5HEGwSCwoHS09GRklORxBtEgsKB1dFRVpJTkcQbhILCgdS",
-            "SFlIT1JOEG8SCgoGUkhZRE9OEHASCwoHQ0hBTlNFWRBxEgsKB1RBTkdFTEEQ",
-            "chIOCgpLQU5HQVNLSEFOEHMSCgoGSE9SU0VBEHQSCgoGU0VBRFJBEHUSCwoH",
-            "R09MREVFThB2EgsKB1NFQUtJTkcQdxIKCgZTVEFSWVUQeBILCgdTVEFSTUlF",
-            "EHkSCwoHTVJfTUlNRRB6EgsKB1NDWVRIRVIQexIICgRKWU5YEHwSDgoKRUxF",
-            "Q1RBQlVaWhB9EgoKBk1BR01BUhB+EgoKBlBJTlNJUhB/EgsKBlRBVVJPUxCA",
-            "ARINCghNQUdJS0FSUBCBARINCghHWUFSQURPUxCCARILCgZMQVBSQVMQgwES",
-            "CgoFRElUVE8QhAESCgoFRUVWRUUQhQESDQoIVkFQT1JFT04QhgESDAoHSk9M",
-            "VEVPThCHARIMCgdGTEFSRU9OEIgBEgwKB1BPUllHT04QiQESDAoHT01BTllU",
-            "RRCKARIMCgdPTUFTVEFSEIsBEgsKBktBQlVUTxCMARINCghLQUJVVE9QUxCN",
-            "ARIPCgpBRVJPREFDVFlMEI4BEgwKB1NOT1JMQVgQjwESDQoIQVJUSUNVTk8Q",
-            "kAESCwoGWkFQRE9TEJEBEgwKB01PTFRSRVMQkgESDAoHRFJBVElOSRCTARIO",
-            "CglEUkFHT05BSVIQlAESDgoJRFJBR09OSVRFEJUBEgsKBk1FV1RXTxCWARII",
-            "CgNNRVcQlwEqQgoLRm9ydFNwb25zb3ISEQoNVU5TRVRfU1BPTlNPUhAAEg0K",
-            "CU1DRE9OQUxEUxABEhEKDVBPS0VNT05fU1RPUkUQAiozChFGb3J0UmVuZGVy",
-            "aW5nVHlwZRILCgdERUZBVUxUEAASEQoNSU5URVJOQUxfVEVTVBABKrICCghJ",
-            "dGVtVHlwZRISCg5JVEVNX1RZUEVfTk9ORRAAEhYKEklURU1fVFlQRV9QT0tF",
-            "QkFMTBABEhQKEElURU1fVFlQRV9QT1RJT04QAhIUChBJVEVNX1RZUEVfUkVW",
-            "SVZFEAMSEQoNSVRFTV9UWVBFX01BUBAEEhQKEElURU1fVFlQRV9CQVRUTEUQ",
-            "BRISCg5JVEVNX1RZUEVfRk9PRBAGEhQKEElURU1fVFlQRV9DQU1FUkEQBxIS",
-            "Cg5JVEVNX1RZUEVfRElTSxAIEhcKE0lURU1fVFlQRV9JTkNVQkFUT1IQCRIV",
-            "ChFJVEVNX1RZUEVfSU5DRU5TRRAKEhYKEklURU1fVFlQRV9YUF9CT09TVBAL",
-            "Eh8KG0lURU1fVFlQRV9JTlZFTlRPUllfVVBHUkFERRAMKtYCCgxJdGVtQ2F0",
-            "ZWdvcnkSFgoSSVRFTV9DQVRFR09SWV9OT05FEAASGgoWSVRFTV9DQVRFR09S",
-            "WV9QT0tFQkFMTBABEhYKEklURU1fQ0FURUdPUllfRk9PRBACEhoKFklURU1f",
-            "Q0FURUdPUllfTUVESUNJTkUQAxIXChNJVEVNX0NBVEVHT1JZX0JPT1NUEAQS",
-            "GgoWSVRFTV9DQVRFR09SWV9VVElMSVRFUxAFEhgKFElURU1fQ0FURUdPUllf",
-            "Q0FNRVJBEAYSFgoSSVRFTV9DQVRFR09SWV9ESVNLEAcSGwoXSVRFTV9DQVRF",
-            "R09SWV9JTkNVQkFUT1IQCBIZChVJVEVNX0NBVEVHT1JZX0lOQ0VOU0UQCRIa",
-            "ChZJVEVNX0NBVEVHT1JZX1hQX0JPT1NUEAoSIwofSVRFTV9DQVRFR09SWV9J",
-            "TlZFTlRPUllfVVBHUkFERRALKpgECgpJdGVtRWZmZWN0EhQKEElURU1fRUZG",
-            "RUNUX05PTkUQABIcChdJVEVNX0VGRkVDVF9DQVBfTk9fRkxFRRDoBxIgChtJ",
-            "VEVNX0VGRkVDVF9DQVBfTk9fTU9WRU1FTlQQ6gcSHgoZSVRFTV9FRkZFQ1Rf",
-            "Q0FQX05PX1RIUkVBVBDrBxIfChpJVEVNX0VGRkVDVF9DQVBfVEFSR0VUX01B",
-            "WBDsBxIgChtJVEVNX0VGRkVDVF9DQVBfVEFSR0VUX1NMT1cQ7QcSIQocSVRF",
-            "TV9FRkZFQ1RfQ0FQX0NIQU5DRV9OSUdIVBDuBxIjCh5JVEVNX0VGRkVDVF9D",
-            "QVBfQ0hBTkNFX1RSQUlORVIQ7wcSJwoiSVRFTV9FRkZFQ1RfQ0FQX0NIQU5D",
-            "RV9GSVJTVF9USFJPVxDwBxIiCh1JVEVNX0VGRkVDVF9DQVBfQ0hBTkNFX0xF",
-            "R0VORBDxBxIhChxJVEVNX0VGRkVDVF9DQVBfQ0hBTkNFX0hFQVZZEPIHEiIK",
-            "HUlURU1fRUZGRUNUX0NBUF9DSEFOQ0VfUkVQRUFUEPMHEicKIklURU1fRUZG",
-            "RUNUX0NBUF9DSEFOQ0VfTVVMVElfVEhST1cQ9AcSIgodSVRFTV9FRkZFQ1Rf",
-            "Q0FQX0NIQU5DRV9BTFdBWVMQ9QcSKAojSVRFTV9FRkZFQ1RfQ0FQX0NIQU5D",
-            "RV9TSU5HTEVfVEhST1cQ9gcq7AUKDEFjdGl2aXR5VHlwZRIUChBBQ1RJVklU",
-            "WV9VTktOT1dOEAASGgoWQUNUSVZJVFlfQ0FUQ0hfUE9LRU1PThABEiEKHUFD",
-            "VElWSVRZX0NBVENIX0xFR0VORF9QT0tFTU9OEAISGQoVQUNUSVZJVFlfRkxF",
-            "RV9QT0tFTU9OEAMSGAoUQUNUSVZJVFlfREVGRUFUX0ZPUlQQBBIbChdBQ1RJ",
-            "VklUWV9FVk9MVkVfUE9LRU1PThAFEhYKEkFDVElWSVRZX0hBVENIX0VHRxAG",
-            "EhQKEEFDVElWSVRZX1dBTEtfS00QBxIeChpBQ1RJVklUWV9QT0tFREVYX0VO",
-            "VFJZX05FVxAIEh4KGkFDVElWSVRZX0NBVENIX0ZJUlNUX1RIUk9XEAkSHQoZ",
-            "QUNUSVZJVFlfQ0FUQ0hfTklDRV9USFJPVxAKEh4KGkFDVElWSVRZX0NBVENI",
-            "X0dSRUFUX1RIUk9XEAsSIgoeQUNUSVZJVFlfQ0FUQ0hfRVhDRUxMRU5UX1RI",
-            "Uk9XEAwSHAoYQUNUSVZJVFlfQ0FUQ0hfQ1VSVkVCQUxMEA0SJQohQUNUSVZJ",
-            "VFlfQ0FUQ0hfRklSU1RfQ0FUQ0hfT0ZfREFZEA4SHAoYQUNUSVZJVFlfQ0FU",
-            "Q0hfTUlMRVNUT05FEA8SGgoWQUNUSVZJVFlfVFJBSU5fUE9LRU1PThAQEhgK",
-            "FEFDVElWSVRZX1NFQVJDSF9GT1JUEBESHAoYQUNUSVZJVFlfUkVMRUFTRV9Q",
-            "T0tFTU9OEBISIgoeQUNUSVZJVFlfSEFUQ0hfRUdHX1NNQUxMX0JPTlVTEBMS",
-            "IwofQUNUSVZJVFlfSEFUQ0hfRUdHX01FRElVTV9CT05VUxAUEiIKHkFDVElW",
-            "SVRZX0hBVENIX0VHR19MQVJHRV9CT05VUxAVEiAKHEFDVElWSVRZX0RFRkVB",
-            "VF9HWU1fREVGRU5ERVIQFhIeChpBQ1RJVklUWV9ERUZFQVRfR1lNX0xFQURF",
-            "UhAXKqEHCglCYWRnZVR5cGUSDwoLQkFER0VfVU5TRVQQABITCg9CQURHRV9U",
-            "UkFWRUxfS00QARIZChVCQURHRV9QT0tFREVYX0VOVFJJRVMQAhIXChNCQURH",
-            "RV9DQVBUVVJFX1RPVEFMEAMSFwoTQkFER0VfREVGRUFURURfRk9SVBAEEhcK",
-            "E0JBREdFX0VWT0xWRURfVE9UQUwQBRIXChNCQURHRV9IQVRDSEVEX1RPVEFM",
-            "EAYSGwoXQkFER0VfRU5DT1VOVEVSRURfVE9UQUwQBxIbChdCQURHRV9QT0tF",
-            "U1RPUFNfVklTSVRFRBAIEhoKFkJBREdFX1VOSVFVRV9QT0tFU1RPUFMQCRIZ",
-            "ChVCQURHRV9QT0tFQkFMTF9USFJPV04QChIWChJCQURHRV9CSUdfTUFHSUtB",
-            "UlAQCxIYChRCQURHRV9ERVBMT1lFRF9UT1RBTBAMEhsKF0JBREdFX0JBVFRM",
-            "RV9BVFRBQ0tfV09OEA0SHQoZQkFER0VfQkFUVExFX1RSQUlOSU5HX1dPThAO",
-            "EhsKF0JBREdFX0JBVFRMRV9ERUZFTkRfV09OEA8SGQoVQkFER0VfUFJFU1RJ",
-            "R0VfUkFJU0VEEBASGgoWQkFER0VfUFJFU1RJR0VfRFJPUFBFRBAREhUKEUJB",
-            "REdFX1RZUEVfTk9STUFMEBISFwoTQkFER0VfVFlQRV9GSUdIVElORxATEhUK",
-            "EUJBREdFX1RZUEVfRkxZSU5HEBQSFQoRQkFER0VfVFlQRV9QT0lTT04QFRIV",
-            "ChFCQURHRV9UWVBFX0dST1VORBAWEhMKD0JBREdFX1RZUEVfUk9DSxAXEhIK",
-            "DkJBREdFX1RZUEVfQlVHEBgSFAoQQkFER0VfVFlQRV9HSE9TVBAZEhQKEEJB",
-            "REdFX1RZUEVfU1RFRUwQGhITCg9CQURHRV9UWVBFX0ZJUkUQGxIUChBCQURH",
-            "RV9UWVBFX1dBVEVSEBwSFAoQQkFER0VfVFlQRV9HUkFTUxAdEhcKE0JBREdF",
-            "X1RZUEVfRUxFQ1RSSUMQHhIWChJCQURHRV9UWVBFX1BTWUNISUMQHxISCg5C",
-            "QURHRV9UWVBFX0lDRRAgEhUKEUJBREdFX1RZUEVfRFJBR09OECESEwoPQkFE",
-            "R0VfVFlQRV9EQVJLECISFAoQQkFER0VfVFlQRV9GQUlSWRAjEhcKE0JBREdF",
-            "X1NNQUxMX1JBVFRBVEEQJBIRCg1CQURHRV9QSUtBQ0hVECUqlAEKE0hvbG9J",
-            "YXBJdGVtQ2F0ZWdvcnkSFQoRSUFQX0NBVEVHT1JZX05PTkUQABIXChNJQVBf",
-            "Q0FURUdPUllfQlVORExFEAESFgoSSUFQX0NBVEVHT1JZX0lURU1TEAISGQoV",
-            "SUFQX0NBVEVHT1JZX1VQR1JBREVTEAMSGgoWSUFQX0NBVEVHT1JZX1BPS0VD",
-            "T0lOUxAEKpYBChNDYW1lcmFJbnRlcnBvbGF0aW9uEhIKDkNBTV9JTlRFUlBf",
-            "Q1VUEAASFQoRQ0FNX0lOVEVSUF9MSU5FQVIQARIVChFDQU1fSU5URVJQX1NN",
-            "T09USBACEiUKIUNBTV9JTlRFUlBfU01PT1RIX1JPVF9MSU5FQVJfTU9WRRAD",
-            "EhYKEkNBTV9JTlRFUlBfREVQRU5EUxAEKvwDCgxDYW1lcmFUYXJnZXQSFwoT",
-            "Q0FNX1RBUkdFVF9BVFRBQ0tFUhAAEhwKGENBTV9UQVJHRVRfQVRUQUNLRVJf",
-            "RURHRRABEh4KGkNBTV9UQVJHRVRfQVRUQUNLRVJfR1JPVU5EEAISFwoTQ0FN",
-            "X1RBUkdFVF9ERUZFTkRFUhADEhwKGENBTV9UQVJHRVRfREVGRU5ERVJfRURH",
-            "RRAEEh4KGkNBTV9UQVJHRVRfREVGRU5ERVJfR1JPVU5EEAUSIAocQ0FNX1RB",
-            "UkdFVF9BVFRBQ0tFUl9ERUZFTkRFUhAGEiUKIUNBTV9UQVJHRVRfQVRUQUNL",
-            "RVJfREVGRU5ERVJfRURHRRAHEiAKHENBTV9UQVJHRVRfREVGRU5ERVJfQVRU",
-            "QUNLRVIQCBIlCiFDQU1fVEFSR0VUX0RFRkVOREVSX0FUVEFDS0VSX0VER0UQ",
-            "CRInCiNDQU1fVEFSR0VUX0FUVEFDS0VSX0RFRkVOREVSX01JUlJPUhALEikK",
-            "JUNBTV9UQVJHRVRfU0hPVUxERVJfQVRUQUNLRVJfREVGRU5ERVIQDBIwCixD",
-            "QU1fVEFSR0VUX1NIT1VMREVSX0FUVEFDS0VSX0RFRkVOREVSX01JUlJPUhAN",
-            "EiYKIkNBTV9UQVJHRVRfQVRUQUNLRVJfREVGRU5ERVJfV09STEQQDiraAwoL",
-            "UG9rZW1vblR5cGUSFQoRUE9LRU1PTl9UWVBFX05PTkUQABIXChNQT0tFTU9O",
-            "X1RZUEVfTk9STUFMEAESGQoVUE9LRU1PTl9UWVBFX0ZJR0hUSU5HEAISFwoT",
-            "UE9LRU1PTl9UWVBFX0ZMWUlORxADEhcKE1BPS0VNT05fVFlQRV9QT0lTT04Q",
-            "BBIXChNQT0tFTU9OX1RZUEVfR1JPVU5EEAUSFQoRUE9LRU1PTl9UWVBFX1JP",
-            "Q0sQBhIUChBQT0tFTU9OX1RZUEVfQlVHEAcSFgoSUE9LRU1PTl9UWVBFX0dI",
-            "T1NUEAgSFgoSUE9LRU1PTl9UWVBFX1NURUVMEAkSFQoRUE9LRU1PTl9UWVBF",
-            "X0ZJUkUQChIWChJQT0tFTU9OX1RZUEVfV0FURVIQCxIWChJQT0tFTU9OX1RZ",
-            "UEVfR1JBU1MQDBIZChVQT0tFTU9OX1RZUEVfRUxFQ1RSSUMQDRIYChRQT0tF",
-            "TU9OX1RZUEVfUFNZQ0hJQxAOEhQKEFBPS0VNT05fVFlQRV9JQ0UQDxIXChNQ",
-            "T0tFTU9OX1RZUEVfRFJBR09OEBASFQoRUE9LRU1PTl9UWVBFX0RBUksQERIW",
-            "ChJQT0tFTU9OX1RZUEVfRkFJUlkQEiqtAQoTUG9rZW1vbk1vdmVtZW50VHlw",
-            "ZRITCg9NT1ZFTUVOVF9TVEFUSUMQABIRCg1NT1ZFTUVOVF9KVU1QEAESFQoR",
-            "TU9WRU1FTlRfVkVSVElDQUwQAhIUChBNT1ZFTUVOVF9QU1lDSElDEAMSFQoR",
-            "TU9WRU1FTlRfRUxFQ1RSSUMQBBITCg9NT1ZFTUVOVF9GTFlJTkcQBRIVChFN",
-            "T1ZFTUVOVF9IT1ZFUklORxAGKjUKDFBva2Vtb25DbGFzcxIKCgZOT1JNQUwQ",
-            "ABINCglMRUdFTkRBUlkQARIKCgZNWVRISUMQAkIkqgIhUG9rZW1vbkdvLlJv",
-            "Y2tldEFQSS5HZW5lcmF0ZWRDb2RlYgZwcm90bzM="));
-      descriptor = pbr::FileDescriptor.FromGeneratedCode(descriptorData,
-          new pbr::FileDescriptor[] { },
-          new pbr::GeneratedClrTypeInfo(new[] {typeof(global::PokemonGo.RocketAPI.GeneratedCode.RpcDirection), typeof(global::PokemonGo.RocketAPI.GeneratedCode.TeamColor), typeof(global::PokemonGo.RocketAPI.GeneratedCode.RequestMethod), typeof(global::PokemonGo.RocketAPI.GeneratedCode.PokemonMove), typeof(global::PokemonGo.RocketAPI.GeneratedCode.ItemId), typeof(global::PokemonGo.RocketAPI.GeneratedCode.InventoryUpgradeType), typeof(global::PokemonGo.RocketAPI.GeneratedCode.EggIncubatorType), typeof(global::PokemonGo.RocketAPI.GeneratedCode.PokemonFamilyId), typeof(global::PokemonGo.RocketAPI.GeneratedCode.MapObjectsStatus), typeof(global::PokemonGo.RocketAPI.GeneratedCode.FortType), typeof(global::PokemonGo.RocketAPI.GeneratedCode.PokemonId), typeof(global::PokemonGo.RocketAPI.GeneratedCode.FortSponsor), typeof(global::PokemonGo.RocketAPI.GeneratedCode.FortRenderingType), typeof(global::PokemonGo.RocketAPI.GeneratedCode.ItemType), typeof(global::PokemonGo.RocketAPI.GeneratedCode.ItemCategory), typeof(global::PokemonGo.RocketAPI.GeneratedCode.ItemEffect), typeof(global::PokemonGo.RocketAPI.GeneratedCode.ActivityType), typeof(global::PokemonGo.RocketAPI.GeneratedCode.BadgeType), typeof(global::PokemonGo.RocketAPI.GeneratedCode.HoloIapItemCategory), typeof(global::PokemonGo.RocketAPI.GeneratedCode.CameraInterpolation), typeof(global::PokemonGo.RocketAPI.GeneratedCode.CameraTarget), typeof(global::PokemonGo.RocketAPI.GeneratedCode.PokemonType), typeof(global::PokemonGo.RocketAPI.GeneratedCode.PokemonMovementType), typeof(global::PokemonGo.RocketAPI.GeneratedCode.PokemonClass), }, null));
-    }
-    #endregion
-
-  }
-  #region Enums
-  public enum RpcDirection {
-    [pbr::OriginalName("UNKNOWN")] Unknown = 0,
-    [pbr::OriginalName("RESPONSE")] Response = 1,
-    [pbr::OriginalName("REQUEST")] Request = 2,
-  }
-
-  public enum TeamColor {
-    [pbr::OriginalName("NEUTRAL")] Neutral = 0,
-    [pbr::OriginalName("BLUE")] Blue = 1,
-    [pbr::OriginalName("RED")] Red = 2,
-    [pbr::OriginalName("YELLOW")] Yellow = 3,
-  }
-
-  public enum RequestMethod {
-    [pbr::OriginalName("METHOD_UNSET")] MethodUnset = 0,
-    [pbr::OriginalName("PLAYER_UPDATE")] PlayerUpdate = 1,
-    [pbr::OriginalName("GET_PLAYER")] GetPlayer = 2,
-    [pbr::OriginalName("GET_INVENTORY")] GetInventory = 4,
-    [pbr::OriginalName("DOWNLOAD_SETTINGS")] DownloadSettings = 5,
-    [pbr::OriginalName("DOWNLOAD_ITEM_TEMPLATES")] DownloadItemTemplates = 6,
-    [pbr::OriginalName("DOWNLOAD_REMOTE_CONFIG_VERSION")] DownloadRemoteConfigVersion = 7,
-    [pbr::OriginalName("FORT_SEARCH")] FortSearch = 101,
-    [pbr::OriginalName("ENCOUNTER")] Encounter = 102,
-    [pbr::OriginalName("CATCH_POKEMON")] CatchPokemon = 103,
-    [pbr::OriginalName("FORT_DETAILS")] FortDetails = 104,
-    [pbr::OriginalName("ITEM_USE")] ItemUse = 105,
-    [pbr::OriginalName("GET_MAP_OBJECTS")] GetMapObjects = 106,
-    [pbr::OriginalName("FORT_DEPLOY_POKEMON")] FortDeployPokemon = 110,
-    [pbr::OriginalName("FORT_RECALL_POKEMON")] FortRecallPokemon = 111,
-    [pbr::OriginalName("RELEASE_POKEMON")] ReleasePokemon = 112,
-    [pbr::OriginalName("USE_ITEM_POTION")] UseItemPotion = 113,
-    [pbr::OriginalName("USE_ITEM_CAPTURE")] UseItemCapture = 114,
-    [pbr::OriginalName("USE_ITEM_FLEE")] UseItemFlee = 115,
-    [pbr::OriginalName("USE_ITEM_REVIVE")] UseItemRevive = 116,
-    [pbr::OriginalName("TRADE_SEARCH")] TradeSearch = 117,
-    [pbr::OriginalName("TRADE_OFFER")] TradeOffer = 118,
-    [pbr::OriginalName("TRADE_RESPONSE")] TradeResponse = 119,
-    [pbr::OriginalName("TRADE_RESULT")] TradeResult = 120,
-    [pbr::OriginalName("GET_PLAYER_PROFILE")] GetPlayerProfile = 121,
-    [pbr::OriginalName("GET_ITEM_PACK")] GetItemPack = 122,
-    [pbr::OriginalName("BUY_ITEM_PACK")] BuyItemPack = 123,
-    [pbr::OriginalName("BUY_GEM_PACK")] BuyGemPack = 124,
-    [pbr::OriginalName("EVOLVE_POKEMON")] EvolvePokemon = 125,
-    [pbr::OriginalName("GET_HATCHED_EGGS")] GetHatchedEggs = 126,
-    [pbr::OriginalName("ENCOUNTER_TUTORIAL_COMPLETE")] EncounterTutorialComplete = 127,
-    [pbr::OriginalName("LEVEL_UP_REWARDS")] LevelUpRewards = 128,
-    [pbr::OriginalName("CHECK_AWARDED_BADGES")] CheckAwardedBadges = 129,
-    [pbr::OriginalName("USE_ITEM_GYM")] UseItemGym = 133,
-    [pbr::OriginalName("GET_GYM_DETAILS")] GetGymDetails = 134,
-    [pbr::OriginalName("START_GYM_BATTLE")] StartGymBattle = 135,
-    [pbr::OriginalName("ATTACK_GYM")] AttackGym = 136,
-    [pbr::OriginalName("RECYCLE_INVENTORY_ITEM")] RecycleInventoryItem = 137,
-    [pbr::OriginalName("COLLECT_DAILY_BONUS")] CollectDailyBonus = 138,
-    [pbr::OriginalName("USE_ITEM_XP_BOOST")] UseItemXpBoost = 139,
-    [pbr::OriginalName("USE_ITEM_EGG_INCUBATOR")] UseItemEggIncubator = 140,
-    [pbr::OriginalName("USE_INCENSE")] UseIncense = 141,
-    [pbr::OriginalName("GET_INCENSE_POKEMON")] GetIncensePokemon = 142,
-    [pbr::OriginalName("INCENSE_ENCOUNTER")] IncenseEncounter = 143,
-    [pbr::OriginalName("ADD_FORT_MODIFIER")] AddFortModifier = 144,
-    [pbr::OriginalName("DISK_ENCOUNTER")] DiskEncounter = 145,
-    [pbr::OriginalName("COLLECT_DAILY_DEFENDER_BONUS")] CollectDailyDefenderBonus = 146,
-    [pbr::OriginalName("UPGRADE_POKEMON")] UpgradePokemon = 147,
-    [pbr::OriginalName("SET_FAVORITE_POKEMON")] SetFavoritePokemon = 148,
-    [pbr::OriginalName("NICKNAME_POKEMON")] NicknamePokemon = 149,
-    [pbr::OriginalName("EQUIP_BADGE")] EquipBadge = 150,
-    [pbr::OriginalName("SET_CONTACT_SETTINGS")] SetContactSettings = 151,
-    [pbr::OriginalName("GET_ASSET_DIGEST")] GetAssetDigest = 300,
-    [pbr::OriginalName("GET_DOWNLOAD_URLS")] GetDownloadUrls = 301,
-    [pbr::OriginalName("GET_SUGGESTED_CODENAMES")] GetSuggestedCodenames = 401,
-    [pbr::OriginalName("CHECK_CODENAME_AVAILABLE")] CheckCodenameAvailable = 402,
-    [pbr::OriginalName("CLAIM_CODENAME")] ClaimCodename = 403,
-    [pbr::OriginalName("SET_AVATAR")] SetAvatar = 404,
-    [pbr::OriginalName("SET_PLAYER_TEAM")] SetPlayerTeam = 405,
-    [pbr::OriginalName("MARK_TUTORIAL_COMPLETE")] MarkTutorialComplete = 406,
-    [pbr::OriginalName("LOAD_SPAWN_POINTS")] LoadSpawnPoints = 500,
-    [pbr::OriginalName("ECHO")] Echo = 666,
-    [pbr::OriginalName("DEBUG_UPDATE_INVENTORY")] DebugUpdateInventory = 700,
-    [pbr::OriginalName("DEBUG_DELETE_PLAYER")] DebugDeletePlayer = 701,
-    [pbr::OriginalName("SFIDA_REGISTRATION")] SfidaRegistration = 800,
-    [pbr::OriginalName("SFIDA_ACTION_LOG")] SfidaActionLog = 801,
-    [pbr::OriginalName("SFIDA_CERTIFICATION")] SfidaCertification = 802,
-    [pbr::OriginalName("SFIDA_UPDATE")] SfidaUpdate = 803,
-    [pbr::OriginalName("SFIDA_ACTION")] SfidaAction = 804,
-    [pbr::OriginalName("SFIDA_DOWSER")] SfidaDowser = 805,
-    [pbr::OriginalName("SFIDA_CAPTURE")] SfidaCapture = 806,
-  }
-
-  public enum PokemonMove {
-    [pbr::OriginalName("MOVE_UNSET")] MoveUnset = 0,
-    [pbr::OriginalName("THUNDER_SHOCK")] ThunderShock = 1,
-    [pbr::OriginalName("QUICK_ATTACK")] QuickAttack = 2,
-    [pbr::OriginalName("SCRATCH")] Scratch = 3,
-    [pbr::OriginalName("EMBER")] Ember = 4,
-    [pbr::OriginalName("VINE_WHIP")] VineWhip = 5,
-    [pbr::OriginalName("TACKLE")] Tackle = 6,
-    [pbr::OriginalName("RAZOR_LEAF")] RazorLeaf = 7,
-    [pbr::OriginalName("TAKE_DOWN")] TakeDown = 8,
-    [pbr::OriginalName("WATER_GUN")] WaterGun = 9,
-    [pbr::OriginalName("BITE")] Bite = 10,
-    [pbr::OriginalName("POUND")] Pound = 11,
-    [pbr::OriginalName("DOUBLE_SLAP")] DoubleSlap = 12,
-    [pbr::OriginalName("WRAP")] Wrap = 13,
-    [pbr::OriginalName("HYPER_BEAM")] HyperBeam = 14,
-    [pbr::OriginalName("LICK")] Lick = 15,
-    [pbr::OriginalName("DARK_PULSE")] DarkPulse = 16,
-    [pbr::OriginalName("SMOG")] Smog = 17,
-    [pbr::OriginalName("SLUDGE")] Sludge = 18,
-    [pbr::OriginalName("METAL_CLAW")] MetalClaw = 19,
-    [pbr::OriginalName("VICE_GRIP")] ViceGrip = 20,
-    [pbr::OriginalName("FLAME_WHEEL")] FlameWheel = 21,
-    [pbr::OriginalName("MEGAHORN")] Megahorn = 22,
-    [pbr::OriginalName("WING_ATTACK")] WingAttack = 23,
-    [pbr::OriginalName("FLAMETHROWER")] Flamethrower = 24,
-    [pbr::OriginalName("SUCKER_PUNCH")] SuckerPunch = 25,
-    [pbr::OriginalName("DIG")] Dig = 26,
-    [pbr::OriginalName("LOW_KICK")] LowKick = 27,
-    [pbr::OriginalName("CROSS_CHOP")] CrossChop = 28,
-    [pbr::OriginalName("PSYCHO_CUT")] PsychoCut = 29,
-    [pbr::OriginalName("PSYBEAM")] Psybeam = 30,
-    [pbr::OriginalName("EARTHQUAKE")] Earthquake = 31,
-    [pbr::OriginalName("STONE_EDGE")] StoneEdge = 32,
-    [pbr::OriginalName("ICE_PUNCH")] IcePunch = 33,
-    [pbr::OriginalName("HEART_STAMP")] HeartStamp = 34,
-    [pbr::OriginalName("DISCHARGE")] Discharge = 35,
-    [pbr::OriginalName("FLASH_CANNON")] FlashCannon = 36,
-    [pbr::OriginalName("PECK")] Peck = 37,
-    [pbr::OriginalName("DRILL_PECK")] DrillPeck = 38,
-    [pbr::OriginalName("ICE_BEAM")] IceBeam = 39,
-    [pbr::OriginalName("BLIZZARD")] Blizzard = 40,
-    [pbr::OriginalName("AIR_SLASH")] AirSlash = 41,
-    [pbr::OriginalName("HEAT_WAVE")] HeatWave = 42,
-    [pbr::OriginalName("TWINEEDLE")] Twineedle = 43,
-    [pbr::OriginalName("POISON_JAB")] PoisonJab = 44,
-    [pbr::OriginalName("AERIAL_ACE")] AerialAce = 45,
-    [pbr::OriginalName("DRILL_RUN")] DrillRun = 46,
-    [pbr::OriginalName("PETAL_BLIZZARD")] PetalBlizzard = 47,
-    [pbr::OriginalName("MEGA_DRAIN")] MegaDrain = 48,
-    [pbr::OriginalName("BUG_BUZZ")] BugBuzz = 49,
-    [pbr::OriginalName("POISON_FANG")] PoisonFang = 50,
-    [pbr::OriginalName("NIGHT_SLASH")] NightSlash = 51,
-    [pbr::OriginalName("SLASH")] Slash = 52,
-    [pbr::OriginalName("BUBBLE_BEAM")] BubbleBeam = 53,
-    [pbr::OriginalName("SUBMISSION")] Submission = 54,
-    [pbr::OriginalName("KARATE_CHOP")] KarateChop = 55,
-    [pbr::OriginalName("LOW_SWEEP")] LowSweep = 56,
-    [pbr::OriginalName("AQUA_JET")] AquaJet = 57,
-    [pbr::OriginalName("AQUA_TAIL")] AquaTail = 58,
-    [pbr::OriginalName("SEED_BOMB")] SeedBomb = 59,
-    [pbr::OriginalName("PSYSHOCK")] Psyshock = 60,
-    [pbr::OriginalName("ROCK_THROW")] RockThrow = 61,
-    [pbr::OriginalName("ANCIENT_POWER")] AncientPower = 62,
-    [pbr::OriginalName("ROCK_TOMB")] RockTomb = 63,
-    [pbr::OriginalName("ROCK_SLIDE")] RockSlide = 64,
-    [pbr::OriginalName("POWER_GEM")] PowerGem = 65,
-    [pbr::OriginalName("SHADOW_SNEAK")] ShadowSneak = 66,
-    [pbr::OriginalName("SHADOW_PUNCH")] ShadowPunch = 67,
-    [pbr::OriginalName("SHADOW_CLAW")] ShadowClaw = 68,
-    [pbr::OriginalName("OMINOUS_WIND")] OminousWind = 69,
-    [pbr::OriginalName("SHADOW_BALL")] ShadowBall = 70,
-    [pbr::OriginalName("BULLET_PUNCH")] BulletPunch = 71,
-    [pbr::OriginalName("MAGNET_BOMB")] MagnetBomb = 72,
-    [pbr::OriginalName("STEEL_WING")] SteelWing = 73,
-    [pbr::OriginalName("IRON_HEAD")] IronHead = 74,
-    [pbr::OriginalName("PARABOLIC_CHARGE")] ParabolicCharge = 75,
-    [pbr::OriginalName("SPARK")] Spark = 76,
-    [pbr::OriginalName("THUNDER_PUNCH")] ThunderPunch = 77,
-    [pbr::OriginalName("THUNDER")] Thunder = 78,
-    [pbr::OriginalName("THUNDERBOLT")] Thunderbolt = 79,
-    [pbr::OriginalName("TWISTER")] Twister = 80,
-    [pbr::OriginalName("DRAGON_BREATH")] DragonBreath = 81,
-    [pbr::OriginalName("DRAGON_PULSE")] DragonPulse = 82,
-    [pbr::OriginalName("DRAGON_CLAW")] DragonClaw = 83,
-    [pbr::OriginalName("DISARMING_VOICE")] DisarmingVoice = 84,
-    [pbr::OriginalName("DRAINING_KISS")] DrainingKiss = 85,
-    [pbr::OriginalName("DAZZLING_GLEAM")] DazzlingGleam = 86,
-    [pbr::OriginalName("MOONBLAST")] Moonblast = 87,
-    [pbr::OriginalName("PLAY_ROUGH")] PlayRough = 88,
-    [pbr::OriginalName("CROSS_POISON")] CrossPoison = 89,
-    [pbr::OriginalName("SLUDGE_BOMB")] SludgeBomb = 90,
-    [pbr::OriginalName("SLUDGE_WAVE")] SludgeWave = 91,
-    [pbr::OriginalName("GUNK_SHOT")] GunkShot = 92,
-    [pbr::OriginalName("MUD_SHOT")] MudShot = 93,
-    [pbr::OriginalName("BONE_CLUB")] BoneClub = 94,
-    [pbr::OriginalName("BULLDOZE")] Bulldoze = 95,
-    [pbr::OriginalName("MUD_BOMB")] MudBomb = 96,
-    [pbr::OriginalName("FURY_CUTTER")] FuryCutter = 97,
-    [pbr::OriginalName("BUG_BITE")] BugBite = 98,
-    [pbr::OriginalName("SIGNAL_BEAM")] SignalBeam = 99,
-    [pbr::OriginalName("X_SCISSOR")] XScissor = 100,
-    [pbr::OriginalName("FLAME_CHARGE")] FlameCharge = 101,
-    [pbr::OriginalName("FLAME_BURST")] FlameBurst = 102,
-    [pbr::OriginalName("FIRE_BLAST")] FireBlast = 103,
-    [pbr::OriginalName("BRINE")] Brine = 104,
-    [pbr::OriginalName("WATER_PULSE")] WaterPulse = 105,
-    [pbr::OriginalName("SCALD")] Scald = 106,
-    [pbr::OriginalName("HYDRO_PUMP")] HydroPump = 107,
-    [pbr::OriginalName("PSYCHIC")] Psychic = 108,
-    [pbr::OriginalName("PSYSTRIKE")] Psystrike = 109,
-    [pbr::OriginalName("ICE_SHARD")] IceShard = 110,
-    [pbr::OriginalName("ICY_WIND")] IcyWind = 111,
-    [pbr::OriginalName("FROST_BREATH")] FrostBreath = 112,
-    [pbr::OriginalName("ABSORB")] Absorb = 113,
-    [pbr::OriginalName("GIGA_DRAIN")] GigaDrain = 114,
-    [pbr::OriginalName("FIRE_PUNCH")] FirePunch = 115,
-    [pbr::OriginalName("SOLAR_BEAM")] SolarBeam = 116,
-    [pbr::OriginalName("LEAF_BLADE")] LeafBlade = 117,
-    [pbr::OriginalName("POWER_WHIP")] PowerWhip = 118,
-    [pbr::OriginalName("SPLASH")] Splash = 119,
-    [pbr::OriginalName("ACID")] Acid = 120,
-    [pbr::OriginalName("AIR_CUTTER")] AirCutter = 121,
-    [pbr::OriginalName("HURRICANE")] Hurricane = 122,
-    [pbr::OriginalName("BRICK_BREAK")] BrickBreak = 123,
-    [pbr::OriginalName("CUT")] Cut = 124,
-    [pbr::OriginalName("SWIFT")] Swift = 125,
-    [pbr::OriginalName("HORN_ATTACK")] HornAttack = 126,
-    [pbr::OriginalName("STOMP")] Stomp = 127,
-    [pbr::OriginalName("HEADBUTT")] Headbutt = 128,
-    [pbr::OriginalName("HYPER_FANG")] HyperFang = 129,
-    [pbr::OriginalName("SLAM")] Slam = 130,
-    [pbr::OriginalName("BODY_SLAM")] BodySlam = 131,
-    [pbr::OriginalName("REST")] Rest = 132,
-    [pbr::OriginalName("STRUGGLE")] Struggle = 133,
-    [pbr::OriginalName("SCALD_BLASTOISE")] ScaldBlastoise = 134,
-    [pbr::OriginalName("HYDRO_PUMP_BLASTOISE")] HydroPumpBlastoise = 135,
-    [pbr::OriginalName("WRAP_GREEN")] WrapGreen = 136,
-    [pbr::OriginalName("WRAP_PINK")] WrapPink = 137,
-    [pbr::OriginalName("FURY_CUTTER_FAST")] FuryCutterFast = 200,
-    [pbr::OriginalName("BUG_BITE_FAST")] BugBiteFast = 201,
-    [pbr::OriginalName("BITE_FAST")] BiteFast = 202,
-    [pbr::OriginalName("SUCKER_PUNCH_FAST")] SuckerPunchFast = 203,
-    [pbr::OriginalName("DRAGON_BREATH_FAST")] DragonBreathFast = 204,
-    [pbr::OriginalName("THUNDER_SHOCK_FAST")] ThunderShockFast = 205,
-    [pbr::OriginalName("SPARK_FAST")] SparkFast = 206,
-    [pbr::OriginalName("LOW_KICK_FAST")] LowKickFast = 207,
-    [pbr::OriginalName("KARATE_CHOP_FAST")] KarateChopFast = 208,
-    [pbr::OriginalName("EMBER_FAST")] EmberFast = 209,
-    [pbr::OriginalName("WING_ATTACK_FAST")] WingAttackFast = 210,
-    [pbr::OriginalName("PECK_FAST")] PeckFast = 211,
-    [pbr::OriginalName("LICK_FAST")] LickFast = 212,
-    [pbr::OriginalName("SHADOW_CLAW_FAST")] ShadowClawFast = 213,
-    [pbr::OriginalName("VINE_WHIP_FAST")] VineWhipFast = 214,
-    [pbr::OriginalName("RAZOR_LEAF_FAST")] RazorLeafFast = 215,
-    [pbr::OriginalName("MUD_SHOT_FAST")] MudShotFast = 216,
-    [pbr::OriginalName("ICE_SHARD_FAST")] IceShardFast = 217,
-    [pbr::OriginalName("FROST_BREATH_FAST")] FrostBreathFast = 218,
-    [pbr::OriginalName("QUICK_ATTACK_FAST")] QuickAttackFast = 219,
-    [pbr::OriginalName("SCRATCH_FAST")] ScratchFast = 220,
-    [pbr::OriginalName("TACKLE_FAST")] TackleFast = 221,
-    [pbr::OriginalName("POUND_FAST")] PoundFast = 222,
-    [pbr::OriginalName("CUT_FAST")] CutFast = 223,
-    [pbr::OriginalName("POISON_JAB_FAST")] PoisonJabFast = 224,
-    [pbr::OriginalName("ACID_FAST")] AcidFast = 225,
-    [pbr::OriginalName("PSYCHO_CUT_FAST")] PsychoCutFast = 226,
-    [pbr::OriginalName("ROCK_THROW_FAST")] RockThrowFast = 227,
-    [pbr::OriginalName("METAL_CLAW_FAST")] MetalClawFast = 228,
-    [pbr::OriginalName("BULLET_PUNCH_FAST")] BulletPunchFast = 229,
-    [pbr::OriginalName("WATER_GUN_FAST")] WaterGunFast = 230,
-    [pbr::OriginalName("SPLASH_FAST")] SplashFast = 231,
-    [pbr::OriginalName("WATER_GUN_FAST_BLASTOISE")] WaterGunFastBlastoise = 232,
-    [pbr::OriginalName("MUD_SLAP_FAST")] MudSlapFast = 233,
-    [pbr::OriginalName("ZEN_HEADBUTT_FAST")] ZenHeadbuttFast = 234,
-    [pbr::OriginalName("CONFUSION_FAST")] ConfusionFast = 235,
-    [pbr::OriginalName("POISON_STING_FAST")] PoisonStingFast = 236,
-    [pbr::OriginalName("BUBBLE_FAST")] BubbleFast = 237,
-    [pbr::OriginalName("FEINT_ATTACK_FAST")] FeintAttackFast = 238,
-    [pbr::OriginalName("STEEL_WING_FAST")] SteelWingFast = 239,
-    [pbr::OriginalName("FIRE_FANG_FAST")] FireFangFast = 240,
-    [pbr::OriginalName("ROCK_SMASH_FAST")] RockSmashFast = 241,
-  }
-
-  public enum ItemId {
-    [pbr::OriginalName("ITEM_UNKNOWN")] ItemUnknown = 0,
-    [pbr::OriginalName("ITEM_POKE_BALL")] ItemPokeBall = 1,
-    [pbr::OriginalName("ITEM_GREAT_BALL")] ItemGreatBall = 2,
-    [pbr::OriginalName("ITEM_ULTRA_BALL")] ItemUltraBall = 3,
-    [pbr::OriginalName("ITEM_MASTER_BALL")] ItemMasterBall = 4,
-    [pbr::OriginalName("ITEM_POTION")] ItemPotion = 101,
-    [pbr::OriginalName("ITEM_SUPER_POTION")] ItemSuperPotion = 102,
-    [pbr::OriginalName("ITEM_HYPER_POTION")] ItemHyperPotion = 103,
-    [pbr::OriginalName("ITEM_MAX_POTION")] ItemMaxPotion = 104,
-    [pbr::OriginalName("ITEM_REVIVE")] ItemRevive = 201,
-    [pbr::OriginalName("ITEM_MAX_REVIVE")] ItemMaxRevive = 202,
-    [pbr::OriginalName("ITEM_LUCKY_EGG")] ItemLuckyEgg = 301,
-    [pbr::OriginalName("ITEM_INCENSE_ORDINARY")] ItemIncenseOrdinary = 401,
-    [pbr::OriginalName("ITEM_INCENSE_SPICY")] ItemIncenseSpicy = 402,
-    [pbr::OriginalName("ITEM_INCENSE_COOL")] ItemIncenseCool = 403,
-    [pbr::OriginalName("ITEM_INCENSE_FLORAL")] ItemIncenseFloral = 404,
-    [pbr::OriginalName("ITEM_TROY_DISK")] ItemTroyDisk = 501,
-    [pbr::OriginalName("ITEM_X_ATTACK")] ItemXAttack = 602,
-    [pbr::OriginalName("ITEM_X_DEFENSE")] ItemXDefense = 603,
-    [pbr::OriginalName("ITEM_X_MIRACLE")] ItemXMiracle = 604,
-    [pbr::OriginalName("ITEM_RAZZ_BERRY")] ItemRazzBerry = 701,
-    [pbr::OriginalName("ITEM_BLUK_BERRY")] ItemBlukBerry = 702,
-    [pbr::OriginalName("ITEM_NANAB_BERRY")] ItemNanabBerry = 703,
-    [pbr::OriginalName("ITEM_WEPAR_BERRY")] ItemWeparBerry = 704,
-    [pbr::OriginalName("ITEM_PINAP_BERRY")] ItemPinapBerry = 705,
-    [pbr::OriginalName("ITEM_SPECIAL_CAMERA")] ItemSpecialCamera = 801,
-    [pbr::OriginalName("ITEM_INCUBATOR_BASIC_UNLIMITED")] ItemIncubatorBasicUnlimited = 901,
-    [pbr::OriginalName("ITEM_INCUBATOR_BASIC")] ItemIncubatorBasic = 902,
-    [pbr::OriginalName("ITEM_POKEMON_STORAGE_UPGRADE")] ItemPokemonStorageUpgrade = 1001,
-    [pbr::OriginalName("ITEM_ITEM_STORAGE_UPGRADE")] ItemItemStorageUpgrade = 1002,
-  }
-
-  public enum InventoryUpgradeType {
-    [pbr::OriginalName("UPGRADE_UNSET")] UpgradeUnset = 0,
-    [pbr::OriginalName("INCREASE_ITEM_STORAGE")] IncreaseItemStorage = 1,
-    [pbr::OriginalName("INCREASE_POKEMON_STORAGE")] IncreasePokemonStorage = 2,
-  }
-
-  public enum EggIncubatorType {
-    [pbr::OriginalName("INCUBATOR_UNSET")] IncubatorUnset = 0,
-    [pbr::OriginalName("INCUBATOR_DISTANCE")] IncubatorDistance = 1,
-  }
-
-  public enum PokemonFamilyId {
-    [pbr::OriginalName("FAMILY_UNSET")] FamilyUnset = 0,
-    [pbr::OriginalName("FAMILY_BULBASAUR")] FamilyBulbasaur = 1,
-    [pbr::OriginalName("FAMILY_CHARMANDER")] FamilyCharmander = 4,
-    [pbr::OriginalName("FAMILY_SQUIRTLE")] FamilySquirtle = 7,
-    [pbr::OriginalName("FAMILY_CATERPIE")] FamilyCaterpie = 10,
-    [pbr::OriginalName("FAMILY_WEEDLE")] FamilyWeedle = 13,
-    [pbr::OriginalName("FAMILY_PIDGEY")] FamilyPidgey = 16,
-    [pbr::OriginalName("FAMILY_RATTATA")] FamilyRattata = 19,
-    [pbr::OriginalName("FAMILY_SPEAROW")] FamilySpearow = 21,
-    [pbr::OriginalName("FAMILY_EKANS")] FamilyEkans = 23,
-    [pbr::OriginalName("FAMILY_PIKACHU")] FamilyPikachu = 25,
-    [pbr::OriginalName("FAMILY_SANDSHREW")] FamilySandshrew = 27,
-    [pbr::OriginalName("FAMILY_NIDORAN")] FamilyNidoran = 29,
-    [pbr::OriginalName("FAMILY_NIDORAN2")] FamilyNidoran2 = 32,
-    [pbr::OriginalName("FAMILY_CLEFAIRY")] FamilyClefairy = 35,
-    [pbr::OriginalName("FAMILY_VULPIX")] FamilyVulpix = 37,
-    [pbr::OriginalName("FAMILY_JIGGLYPUFF")] FamilyJigglypuff = 39,
-    [pbr::OriginalName("FAMILY_ZUBAT")] FamilyZubat = 41,
-    [pbr::OriginalName("FAMILY_ODDISH")] FamilyOddish = 43,
-    [pbr::OriginalName("FAMILY_PARAS")] FamilyParas = 46,
-    [pbr::OriginalName("FAMILY_VENONAT")] FamilyVenonat = 48,
-    [pbr::OriginalName("FAMILY_DIGLETT")] FamilyDiglett = 50,
-    [pbr::OriginalName("FAMILY_MEOWTH")] FamilyMeowth = 52,
-    [pbr::OriginalName("FAMILY_PSYDUCK")] FamilyPsyduck = 54,
-    [pbr::OriginalName("FAMILY_MANKEY")] FamilyMankey = 56,
-    [pbr::OriginalName("FAMILY_GROWLITHE")] FamilyGrowlithe = 58,
-    [pbr::OriginalName("FAMILY_POLIWAG")] FamilyPoliwag = 60,
-    [pbr::OriginalName("FAMILY_ABRA")] FamilyAbra = 63,
-    [pbr::OriginalName("FAMILY_MACHOP")] FamilyMachop = 66,
-    [pbr::OriginalName("FAMILY_BELLSPROUT")] FamilyBellsprout = 69,
-    [pbr::OriginalName("FAMILY_TENTACOOL")] FamilyTentacool = 72,
-    [pbr::OriginalName("FAMILY_GEODUDE")] FamilyGeodude = 74,
-    [pbr::OriginalName("FAMILY_PONYTA")] FamilyPonyta = 77,
-    [pbr::OriginalName("FAMILY_SLOWPOKE")] FamilySlowpoke = 79,
-    [pbr::OriginalName("FAMILY_MAGNEMITE")] FamilyMagnemite = 81,
-    [pbr::OriginalName("FAMILY_FARFETCHD")] FamilyFarfetchd = 83,
-    [pbr::OriginalName("FAMILY_DODUO")] FamilyDoduo = 84,
-    [pbr::OriginalName("FAMILY_SEEL")] FamilySeel = 86,
-    [pbr::OriginalName("FAMILY_GRIMER")] FamilyGrimer = 88,
-    [pbr::OriginalName("FAMILY_SHELLDER")] FamilyShellder = 90,
-    [pbr::OriginalName("FAMILY_GASTLY")] FamilyGastly = 92,
-    [pbr::OriginalName("FAMILY_ONIX")] FamilyOnix = 95,
-    [pbr::OriginalName("FAMILY_DROWZEE")] FamilyDrowzee = 96,
-    [pbr::OriginalName("FAMILY_KRABBY")] FamilyKrabby = 98,
-    [pbr::OriginalName("FAMILY_VOLTORB")] FamilyVoltorb = 100,
-    [pbr::OriginalName("FAMILY_EXEGGCUTE")] FamilyExeggcute = 102,
-    [pbr::OriginalName("FAMILY_CUBONE")] FamilyCubone = 104,
-    [pbr::OriginalName("FAMILY_HITMONLEE")] FamilyHitmonlee = 106,
-    [pbr::OriginalName("FAMILY_HITMONCHAN")] FamilyHitmonchan = 107,
-    [pbr::OriginalName("FAMILY_LICKITUNG")] FamilyLickitung = 108,
-    [pbr::OriginalName("FAMILY_KOFFING")] FamilyKoffing = 109,
-    [pbr::OriginalName("FAMILY_RHYHORN")] FamilyRhyhorn = 111,
-    [pbr::OriginalName("FAMILY_CHANSEY")] FamilyChansey = 113,
-    [pbr::OriginalName("FAMILY_TANGELA")] FamilyTangela = 114,
-    [pbr::OriginalName("FAMILY_KANGASKHAN")] FamilyKangaskhan = 115,
-    [pbr::OriginalName("FAMILY_HORSEA")] FamilyHorsea = 116,
-    [pbr::OriginalName("FAMILY_GOLDEEN")] FamilyGoldeen = 118,
-    [pbr::OriginalName("FAMILY_STARYU")] FamilyStaryu = 120,
-    [pbr::OriginalName("FAMILY_MR_MIME")] FamilyMrMime = 122,
-    [pbr::OriginalName("FAMILY_SCYTHER")] FamilyScyther = 123,
-    [pbr::OriginalName("FAMILY_JYNX")] FamilyJynx = 124,
-    [pbr::OriginalName("FAMILY_ELECTABUZZ")] FamilyElectabuzz = 125,
-    [pbr::OriginalName("FAMILY_MAGMAR")] FamilyMagmar = 126,
-    [pbr::OriginalName("FAMILY_PINSIR")] FamilyPinsir = 127,
-    [pbr::OriginalName("FAMILY_TAUROS")] FamilyTauros = 128,
-    [pbr::OriginalName("FAMILY_MAGIKARP")] FamilyMagikarp = 129,
-    [pbr::OriginalName("FAMILY_LAPRAS")] FamilyLapras = 131,
-    [pbr::OriginalName("FAMILY_DITTO")] FamilyDitto = 132,
-    [pbr::OriginalName("FAMILY_EEVEE")] FamilyEevee = 133,
-    [pbr::OriginalName("FAMILY_PORYGON")] FamilyPorygon = 137,
-    [pbr::OriginalName("FAMILY_OMANYTE")] FamilyOmanyte = 138,
-    [pbr::OriginalName("FAMILY_KABUTO")] FamilyKabuto = 140,
-    [pbr::OriginalName("FAMILY_AERODACTYL")] FamilyAerodactyl = 142,
-    [pbr::OriginalName("FAMILY_SNORLAX")] FamilySnorlax = 143,
-    [pbr::OriginalName("FAMILY_ARTICUNO")] FamilyArticuno = 144,
-    [pbr::OriginalName("FAMILY_ZAPDOS")] FamilyZapdos = 145,
-    [pbr::OriginalName("FAMILY_MOLTRES")] FamilyMoltres = 146,
-    [pbr::OriginalName("FAMILY_DRATINI")] FamilyDratini = 147,
-    [pbr::OriginalName("FAMILY_MEWTWO")] FamilyMewtwo = 150,
-    [pbr::OriginalName("FAMILY_MEW")] FamilyMew = 151,
-  }
-
-  public enum MapObjectsStatus {
-    [pbr::OriginalName("UNSET_STATUS")] UnsetStatus = 0,
-    [pbr::OriginalName("SUCCESS")] Success = 1,
-    [pbr::OriginalName("LOCATION_UNSET")] LocationUnset = 2,
-  }
-
-  public enum FortType {
-    [pbr::OriginalName("GYM")] Gym = 0,
-    [pbr::OriginalName("CHECKPOINT")] Checkpoint = 1,
-  }
-
-  public enum PokemonId {
-    [pbr::OriginalName("MISSINGNO")] Missingno = 0,
-    [pbr::OriginalName("BULBASAUR")] Bulbasaur = 1,
-    [pbr::OriginalName("IVYSAUR")] Ivysaur = 2,
-    [pbr::OriginalName("VENUSAUR")] Venusaur = 3,
-    [pbr::OriginalName("CHARMANDER")] Charmander = 4,
-    [pbr::OriginalName("CHARMELEON")] Charmeleon = 5,
-    [pbr::OriginalName("CHARIZARD")] Charizard = 6,
-    [pbr::OriginalName("SQUIRTLE")] Squirtle = 7,
-    [pbr::OriginalName("WARTORTLE")] Wartortle = 8,
-    [pbr::OriginalName("BLASTOISE")] Blastoise = 9,
-    [pbr::OriginalName("CATERPIE")] Caterpie = 10,
-    [pbr::OriginalName("METAPOD")] Metapod = 11,
-    [pbr::OriginalName("BUTTERFREE")] Butterfree = 12,
-    [pbr::OriginalName("WEEDLE")] Weedle = 13,
-    [pbr::OriginalName("KAKUNA")] Kakuna = 14,
-    [pbr::OriginalName("BEEDRILL")] Beedrill = 15,
-    [pbr::OriginalName("PIDGEY")] Pidgey = 16,
-    [pbr::OriginalName("PIDGEOTTO")] Pidgeotto = 17,
-    [pbr::OriginalName("PIDGEOT")] Pidgeot = 18,
-    [pbr::OriginalName("RATTATA")] Rattata = 19,
-    [pbr::OriginalName("RATICATE")] Raticate = 20,
-    [pbr::OriginalName("SPEAROW")] Spearow = 21,
-    [pbr::OriginalName("FEAROW")] Fearow = 22,
-    [pbr::OriginalName("EKANS")] Ekans = 23,
-    [pbr::OriginalName("ARBOK")] Arbok = 24,
-    [pbr::OriginalName("PIKACHU")] Pikachu = 25,
-    [pbr::OriginalName("RAICHU")] Raichu = 26,
-    [pbr::OriginalName("SANDSHREW")] Sandshrew = 27,
-    [pbr::OriginalName("SANDSLASH")] Sandslash = 28,
-    [pbr::OriginalName("NIDORAN_FEMALE")] NidoranFemale = 29,
-    [pbr::OriginalName("NIDORINA")] Nidorina = 30,
-    [pbr::OriginalName("NIDOQUEEN")] Nidoqueen = 31,
-    [pbr::OriginalName("NIDORAN_MALE")] NidoranMale = 32,
-    [pbr::OriginalName("NIDORINO")] Nidorino = 33,
-    [pbr::OriginalName("NIDOKING")] Nidoking = 34,
-    [pbr::OriginalName("CLEFAIRY")] Clefairy = 35,
-    [pbr::OriginalName("CLEFABLE")] Clefable = 36,
-    [pbr::OriginalName("VULPIX")] Vulpix = 37,
-    [pbr::OriginalName("NINETALES")] Ninetales = 38,
-    [pbr::OriginalName("JIGGLYPUFF")] Jigglypuff = 39,
-    [pbr::OriginalName("WIGGLYTUFF")] Wigglytuff = 40,
-    [pbr::OriginalName("ZUBAT")] Zubat = 41,
-    [pbr::OriginalName("GOLBAT")] Golbat = 42,
-    [pbr::OriginalName("ODDISH")] Oddish = 43,
-    [pbr::OriginalName("GLOOM")] Gloom = 44,
-    [pbr::OriginalName("VILEPLUME")] Vileplume = 45,
-    [pbr::OriginalName("PARAS")] Paras = 46,
-    [pbr::OriginalName("PARASECT")] Parasect = 47,
-    [pbr::OriginalName("VENONAT")] Venonat = 48,
-    [pbr::OriginalName("VENOMOTH")] Venomoth = 49,
-    [pbr::OriginalName("DIGLETT")] Diglett = 50,
-    [pbr::OriginalName("DUGTRIO")] Dugtrio = 51,
-    [pbr::OriginalName("MEOWTH")] Meowth = 52,
-    [pbr::OriginalName("PERSIAN")] Persian = 53,
-    [pbr::OriginalName("PSYDUCK")] Psyduck = 54,
-    [pbr::OriginalName("GOLDUCK")] Golduck = 55,
-    [pbr::OriginalName("MANKEY")] Mankey = 56,
-    [pbr::OriginalName("PRIMEAPE")] Primeape = 57,
-    [pbr::OriginalName("GROWLITHE")] Growlithe = 58,
-    [pbr::OriginalName("ARCANINE")] Arcanine = 59,
-    [pbr::OriginalName("POLIWAG")] Poliwag = 60,
-    [pbr::OriginalName("POLIWHIRL")] Poliwhirl = 61,
-    [pbr::OriginalName("POLIWRATH")] Poliwrath = 62,
-    [pbr::OriginalName("ABRA")] Abra = 63,
-    [pbr::OriginalName("KADABRA")] Kadabra = 64,
-    [pbr::OriginalName("ALAKAZAM")] Alakazam = 65,
-    [pbr::OriginalName("MACHOP")] Machop = 66,
-    [pbr::OriginalName("MACHOKE")] Machoke = 67,
-    [pbr::OriginalName("MACHAMP")] Machamp = 68,
-    [pbr::OriginalName("BELLSPROUT")] Bellsprout = 69,
-    [pbr::OriginalName("WEEPINBELL")] Weepinbell = 70,
-    [pbr::OriginalName("VICTREEBEL")] Victreebel = 71,
-    [pbr::OriginalName("TENTACOOL")] Tentacool = 72,
-    [pbr::OriginalName("TENTACRUEL")] Tentacruel = 73,
-    [pbr::OriginalName("GEODUDE")] Geodude = 74,
-    [pbr::OriginalName("GRAVELER")] Graveler = 75,
-    [pbr::OriginalName("GOLEM")] Golem = 76,
-    [pbr::OriginalName("PONYTA")] Ponyta = 77,
-    [pbr::OriginalName("RAPIDASH")] Rapidash = 78,
-    [pbr::OriginalName("SLOWPOKE")] Slowpoke = 79,
-    [pbr::OriginalName("SLOWBRO")] Slowbro = 80,
-    [pbr::OriginalName("MAGNEMITE")] Magnemite = 81,
-    [pbr::OriginalName("MAGNETON")] Magneton = 82,
-    [pbr::OriginalName("FARFETCHD")] Farfetchd = 83,
-    [pbr::OriginalName("DODUO")] Doduo = 84,
-    [pbr::OriginalName("DODRIO")] Dodrio = 85,
-    [pbr::OriginalName("SEEL")] Seel = 86,
-    [pbr::OriginalName("DEWGONG")] Dewgong = 87,
-    [pbr::OriginalName("GRIMER")] Grimer = 88,
-    [pbr::OriginalName("MUK")] Muk = 89,
-    [pbr::OriginalName("SHELLDER")] Shellder = 90,
-    [pbr::OriginalName("CLOYSTER")] Cloyster = 91,
-    [pbr::OriginalName("GASTLY")] Gastly = 92,
-    [pbr::OriginalName("HAUNTER")] Haunter = 93,
-    [pbr::OriginalName("GENGAR")] Gengar = 94,
-    [pbr::OriginalName("ONIX")] Onix = 95,
-    [pbr::OriginalName("DROWZEE")] Drowzee = 96,
-    [pbr::OriginalName("HYPNO")] Hypno = 97,
-    [pbr::OriginalName("KRABBY")] Krabby = 98,
-    [pbr::OriginalName("KINGLER")] Kingler = 99,
-    [pbr::OriginalName("VOLTORB")] Voltorb = 100,
-    [pbr::OriginalName("ELECTRODE")] Electrode = 101,
-    [pbr::OriginalName("EXEGGCUTE")] Exeggcute = 102,
-    [pbr::OriginalName("EXEGGUTOR")] Exeggutor = 103,
-    [pbr::OriginalName("CUBONE")] Cubone = 104,
-    [pbr::OriginalName("MAROWAK")] Marowak = 105,
-    [pbr::OriginalName("HITMONLEE")] Hitmonlee = 106,
-    [pbr::OriginalName("HITMONCHAN")] Hitmonchan = 107,
-    [pbr::OriginalName("LICKITUNG")] Lickitung = 108,
-    [pbr::OriginalName("KOFFING")] Koffing = 109,
-    [pbr::OriginalName("WEEZING")] Weezing = 110,
-    [pbr::OriginalName("RHYHORN")] Rhyhorn = 111,
-    [pbr::OriginalName("RHYDON")] Rhydon = 112,
-    [pbr::OriginalName("CHANSEY")] Chansey = 113,
-    [pbr::OriginalName("TANGELA")] Tangela = 114,
-    [pbr::OriginalName("KANGASKHAN")] Kangaskhan = 115,
-    [pbr::OriginalName("HORSEA")] Horsea = 116,
-    [pbr::OriginalName("SEADRA")] Seadra = 117,
-    [pbr::OriginalName("GOLDEEN")] Goldeen = 118,
-    [pbr::OriginalName("SEAKING")] Seaking = 119,
-    [pbr::OriginalName("STARYU")] Staryu = 120,
-    [pbr::OriginalName("STARMIE")] Starmie = 121,
-    [pbr::OriginalName("MR_MIME")] MrMime = 122,
-    [pbr::OriginalName("SCYTHER")] Scyther = 123,
-    [pbr::OriginalName("JYNX")] Jynx = 124,
-    [pbr::OriginalName("ELECTABUZZ")] Electabuzz = 125,
-    [pbr::OriginalName("MAGMAR")] Magmar = 126,
-    [pbr::OriginalName("PINSIR")] Pinsir = 127,
-    [pbr::OriginalName("TAUROS")] Tauros = 128,
-    [pbr::OriginalName("MAGIKARP")] Magikarp = 129,
-    [pbr::OriginalName("GYARADOS")] Gyarados = 130,
-    [pbr::OriginalName("LAPRAS")] Lapras = 131,
-    [pbr::OriginalName("DITTO")] Ditto = 132,
-    [pbr::OriginalName("EEVEE")] Eevee = 133,
-    [pbr::OriginalName("VAPOREON")] Vaporeon = 134,
-    [pbr::OriginalName("JOLTEON")] Jolteon = 135,
-    [pbr::OriginalName("FLAREON")] Flareon = 136,
-    [pbr::OriginalName("PORYGON")] Porygon = 137,
-    [pbr::OriginalName("OMANYTE")] Omanyte = 138,
-    [pbr::OriginalName("OMASTAR")] Omastar = 139,
-    [pbr::OriginalName("KABUTO")] Kabuto = 140,
-    [pbr::OriginalName("KABUTOPS")] Kabutops = 141,
-    [pbr::OriginalName("AERODACTYL")] Aerodactyl = 142,
-    [pbr::OriginalName("SNORLAX")] Snorlax = 143,
-    [pbr::OriginalName("ARTICUNO")] Articuno = 144,
-    [pbr::OriginalName("ZAPDOS")] Zapdos = 145,
-    [pbr::OriginalName("MOLTRES")] Moltres = 146,
-    [pbr::OriginalName("DRATINI")] Dratini = 147,
-    [pbr::OriginalName("DRAGONAIR")] Dragonair = 148,
-    [pbr::OriginalName("DRAGONITE")] Dragonite = 149,
-    [pbr::OriginalName("MEWTWO")] Mewtwo = 150,
-    [pbr::OriginalName("MEW")] Mew = 151,
-  }
-
-  public enum FortSponsor {
-    [pbr::OriginalName("UNSET_SPONSOR")] UnsetSponsor = 0,
-    [pbr::OriginalName("MCDONALDS")] McDonalds = 1,
-    [pbr::OriginalName("POKEMON_STORE")] PokemonStore = 2,
-  }
-
-  public enum FortRenderingType {
-    [pbr::OriginalName("DEFAULT")] Default = 0,
-    [pbr::OriginalName("INTERNAL_TEST")] InternalTest = 1,
-  }
-
-  public enum ItemType {
-    [pbr::OriginalName("ITEM_TYPE_NONE")] None = 0,
-    [pbr::OriginalName("ITEM_TYPE_POKEBALL")] Pokeball = 1,
-    [pbr::OriginalName("ITEM_TYPE_POTION")] Potion = 2,
-    [pbr::OriginalName("ITEM_TYPE_REVIVE")] Revive = 3,
-    [pbr::OriginalName("ITEM_TYPE_MAP")] Map = 4,
-    [pbr::OriginalName("ITEM_TYPE_BATTLE")] Battle = 5,
-    [pbr::OriginalName("ITEM_TYPE_FOOD")] Food = 6,
-    [pbr::OriginalName("ITEM_TYPE_CAMERA")] Camera = 7,
-    [pbr::OriginalName("ITEM_TYPE_DISK")] Disk = 8,
-    [pbr::OriginalName("ITEM_TYPE_INCUBATOR")] Incubator = 9,
-    [pbr::OriginalName("ITEM_TYPE_INCENSE")] Incense = 10,
-    [pbr::OriginalName("ITEM_TYPE_XP_BOOST")] XpBoost = 11,
-    [pbr::OriginalName("ITEM_TYPE_INVENTORY_UPGRADE")] InventoryUpgrade = 12,
-  }
-
-  public enum ItemCategory {
-    [pbr::OriginalName("ITEM_CATEGORY_NONE")] None = 0,
-    [pbr::OriginalName("ITEM_CATEGORY_POKEBALL")] Pokeball = 1,
-    [pbr::OriginalName("ITEM_CATEGORY_FOOD")] Food = 2,
-    [pbr::OriginalName("ITEM_CATEGORY_MEDICINE")] Medicine = 3,
-    [pbr::OriginalName("ITEM_CATEGORY_BOOST")] Boost = 4,
-    [pbr::OriginalName("ITEM_CATEGORY_UTILITES")] Utilites = 5,
-    [pbr::OriginalName("ITEM_CATEGORY_CAMERA")] Camera = 6,
-    [pbr::OriginalName("ITEM_CATEGORY_DISK")] Disk = 7,
-    [pbr::OriginalName("ITEM_CATEGORY_INCUBATOR")] Incubator = 8,
-    [pbr::OriginalName("ITEM_CATEGORY_INCENSE")] Incense = 9,
-    [pbr::OriginalName("ITEM_CATEGORY_XP_BOOST")] XpBoost = 10,
-    [pbr::OriginalName("ITEM_CATEGORY_INVENTORY_UPGRADE")] InventoryUpgrade = 11,
-  }
-
-  public enum ItemEffect {
-    [pbr::OriginalName("ITEM_EFFECT_NONE")] None = 0,
-    [pbr::OriginalName("ITEM_EFFECT_CAP_NO_FLEE")] CapNoFlee = 1000,
-    [pbr::OriginalName("ITEM_EFFECT_CAP_NO_MOVEMENT")] CapNoMovement = 1002,
-    [pbr::OriginalName("ITEM_EFFECT_CAP_NO_THREAT")] CapNoThreat = 1003,
-    [pbr::OriginalName("ITEM_EFFECT_CAP_TARGET_MAX")] CapTargetMax = 1004,
-    [pbr::OriginalName("ITEM_EFFECT_CAP_TARGET_SLOW")] CapTargetSlow = 1005,
-    [pbr::OriginalName("ITEM_EFFECT_CAP_CHANCE_NIGHT")] CapChanceNight = 1006,
-    [pbr::OriginalName("ITEM_EFFECT_CAP_CHANCE_TRAINER")] CapChanceTrainer = 1007,
-    [pbr::OriginalName("ITEM_EFFECT_CAP_CHANCE_FIRST_THROW")] CapChanceFirstThrow = 1008,
-    [pbr::OriginalName("ITEM_EFFECT_CAP_CHANCE_LEGEND")] CapChanceLegend = 1009,
-    [pbr::OriginalName("ITEM_EFFECT_CAP_CHANCE_HEAVY")] CapChanceHeavy = 1010,
-    [pbr::OriginalName("ITEM_EFFECT_CAP_CHANCE_REPEAT")] CapChanceRepeat = 1011,
-    [pbr::OriginalName("ITEM_EFFECT_CAP_CHANCE_MULTI_THROW")] CapChanceMultiThrow = 1012,
-    [pbr::OriginalName("ITEM_EFFECT_CAP_CHANCE_ALWAYS")] CapChanceAlways = 1013,
-    [pbr::OriginalName("ITEM_EFFECT_CAP_CHANCE_SINGLE_THROW")] CapChanceSingleThrow = 1014,
-  }
-
-  public enum ActivityType {
-    [pbr::OriginalName("ACTIVITY_UNKNOWN")] ActivityUnknown = 0,
-    [pbr::OriginalName("ACTIVITY_CATCH_POKEMON")] ActivityCatchPokemon = 1,
-    [pbr::OriginalName("ACTIVITY_CATCH_LEGEND_POKEMON")] ActivityCatchLegendPokemon = 2,
-    [pbr::OriginalName("ACTIVITY_FLEE_POKEMON")] ActivityFleePokemon = 3,
-    [pbr::OriginalName("ACTIVITY_DEFEAT_FORT")] ActivityDefeatFort = 4,
-    [pbr::OriginalName("ACTIVITY_EVOLVE_POKEMON")] ActivityEvolvePokemon = 5,
-    [pbr::OriginalName("ACTIVITY_HATCH_EGG")] ActivityHatchEgg = 6,
-    [pbr::OriginalName("ACTIVITY_WALK_KM")] ActivityWalkKm = 7,
-    [pbr::OriginalName("ACTIVITY_POKEDEX_ENTRY_NEW")] ActivityPokedexEntryNew = 8,
-    [pbr::OriginalName("ACTIVITY_CATCH_FIRST_THROW")] ActivityCatchFirstThrow = 9,
-    [pbr::OriginalName("ACTIVITY_CATCH_NICE_THROW")] ActivityCatchNiceThrow = 10,
-    [pbr::OriginalName("ACTIVITY_CATCH_GREAT_THROW")] ActivityCatchGreatThrow = 11,
-    [pbr::OriginalName("ACTIVITY_CATCH_EXCELLENT_THROW")] ActivityCatchExcellentThrow = 12,
-    [pbr::OriginalName("ACTIVITY_CATCH_CURVEBALL")] ActivityCatchCurveball = 13,
-    [pbr::OriginalName("ACTIVITY_CATCH_FIRST_CATCH_OF_DAY")] ActivityCatchFirstCatchOfDay = 14,
-    [pbr::OriginalName("ACTIVITY_CATCH_MILESTONE")] ActivityCatchMilestone = 15,
-    [pbr::OriginalName("ACTIVITY_TRAIN_POKEMON")] ActivityTrainPokemon = 16,
-    [pbr::OriginalName("ACTIVITY_SEARCH_FORT")] ActivitySearchFort = 17,
-    [pbr::OriginalName("ACTIVITY_RELEASE_POKEMON")] ActivityReleasePokemon = 18,
-    [pbr::OriginalName("ACTIVITY_HATCH_EGG_SMALL_BONUS")] ActivityHatchEggSmallBonus = 19,
-    [pbr::OriginalName("ACTIVITY_HATCH_EGG_MEDIUM_BONUS")] ActivityHatchEggMediumBonus = 20,
-    [pbr::OriginalName("ACTIVITY_HATCH_EGG_LARGE_BONUS")] ActivityHatchEggLargeBonus = 21,
-    [pbr::OriginalName("ACTIVITY_DEFEAT_GYM_DEFENDER")] ActivityDefeatGymDefender = 22,
-    [pbr::OriginalName("ACTIVITY_DEFEAT_GYM_LEADER")] ActivityDefeatGymLeader = 23,
-  }
-
-  public enum BadgeType {
-    [pbr::OriginalName("BADGE_UNSET")] BadgeUnset = 0,
-    [pbr::OriginalName("BADGE_TRAVEL_KM")] BadgeTravelKm = 1,
-    [pbr::OriginalName("BADGE_POKEDEX_ENTRIES")] BadgePokedexEntries = 2,
-    [pbr::OriginalName("BADGE_CAPTURE_TOTAL")] BadgeCaptureTotal = 3,
-    [pbr::OriginalName("BADGE_DEFEATED_FORT")] BadgeDefeatedFort = 4,
-    [pbr::OriginalName("BADGE_EVOLVED_TOTAL")] BadgeEvolvedTotal = 5,
-    [pbr::OriginalName("BADGE_HATCHED_TOTAL")] BadgeHatchedTotal = 6,
-    [pbr::OriginalName("BADGE_ENCOUNTERED_TOTAL")] BadgeEncounteredTotal = 7,
-    [pbr::OriginalName("BADGE_POKESTOPS_VISITED")] BadgePokestopsVisited = 8,
-    [pbr::OriginalName("BADGE_UNIQUE_POKESTOPS")] BadgeUniquePokestops = 9,
-    [pbr::OriginalName("BADGE_POKEBALL_THROWN")] BadgePokeballThrown = 10,
-    [pbr::OriginalName("BADGE_BIG_MAGIKARP")] BadgeBigMagikarp = 11,
-    [pbr::OriginalName("BADGE_DEPLOYED_TOTAL")] BadgeDeployedTotal = 12,
-    [pbr::OriginalName("BADGE_BATTLE_ATTACK_WON")] BadgeBattleAttackWon = 13,
-    [pbr::OriginalName("BADGE_BATTLE_TRAINING_WON")] BadgeBattleTrainingWon = 14,
-    [pbr::OriginalName("BADGE_BATTLE_DEFEND_WON")] BadgeBattleDefendWon = 15,
-    [pbr::OriginalName("BADGE_PRESTIGE_RAISED")] BadgePrestigeRaised = 16,
-    [pbr::OriginalName("BADGE_PRESTIGE_DROPPED")] BadgePrestigeDropped = 17,
-    [pbr::OriginalName("BADGE_TYPE_NORMAL")] Normal = 18,
-    [pbr::OriginalName("BADGE_TYPE_FIGHTING")] Fighting = 19,
-    [pbr::OriginalName("BADGE_TYPE_FLYING")] Flying = 20,
-    [pbr::OriginalName("BADGE_TYPE_POISON")] Poison = 21,
-    [pbr::OriginalName("BADGE_TYPE_GROUND")] Ground = 22,
-    [pbr::OriginalName("BADGE_TYPE_ROCK")] Rock = 23,
-    [pbr::OriginalName("BADGE_TYPE_BUG")] Bug = 24,
-    [pbr::OriginalName("BADGE_TYPE_GHOST")] Ghost = 25,
-    [pbr::OriginalName("BADGE_TYPE_STEEL")] Steel = 26,
-    [pbr::OriginalName("BADGE_TYPE_FIRE")] Fire = 27,
-    [pbr::OriginalName("BADGE_TYPE_WATER")] Water = 28,
-    [pbr::OriginalName("BADGE_TYPE_GRASS")] Grass = 29,
-    [pbr::OriginalName("BADGE_TYPE_ELECTRIC")] Electric = 30,
-    [pbr::OriginalName("BADGE_TYPE_PSYCHIC")] Psychic = 31,
-    [pbr::OriginalName("BADGE_TYPE_ICE")] Ice = 32,
-    [pbr::OriginalName("BADGE_TYPE_DRAGON")] Dragon = 33,
-    [pbr::OriginalName("BADGE_TYPE_DARK")] Dark = 34,
-    [pbr::OriginalName("BADGE_TYPE_FAIRY")] Fairy = 35,
-    [pbr::OriginalName("BADGE_SMALL_RATTATA")] BadgeSmallRattata = 36,
-    [pbr::OriginalName("BADGE_PIKACHU")] BadgePikachu = 37,
-  }
-
-  public enum HoloIapItemCategory {
-    [pbr::OriginalName("IAP_CATEGORY_NONE")] IapCategoryNone = 0,
-    [pbr::OriginalName("IAP_CATEGORY_BUNDLE")] IapCategoryBundle = 1,
-    [pbr::OriginalName("IAP_CATEGORY_ITEMS")] IapCategoryItems = 2,
-    [pbr::OriginalName("IAP_CATEGORY_UPGRADES")] IapCategoryUpgrades = 3,
-    [pbr::OriginalName("IAP_CATEGORY_POKECOINS")] IapCategoryPokecoins = 4,
-  }
-
-  public enum CameraInterpolation {
-    [pbr::OriginalName("CAM_INTERP_CUT")] CamInterpCut = 0,
-    [pbr::OriginalName("CAM_INTERP_LINEAR")] CamInterpLinear = 1,
-    [pbr::OriginalName("CAM_INTERP_SMOOTH")] CamInterpSmooth = 2,
-    [pbr::OriginalName("CAM_INTERP_SMOOTH_ROT_LINEAR_MOVE")] CamInterpSmoothRotLinearMove = 3,
-    [pbr::OriginalName("CAM_INTERP_DEPENDS")] CamInterpDepends = 4,
-  }
-
-  public enum CameraTarget {
-    [pbr::OriginalName("CAM_TARGET_ATTACKER")] CamTargetAttacker = 0,
-    [pbr::OriginalName("CAM_TARGET_ATTACKER_EDGE")] CamTargetAttackerEdge = 1,
-    [pbr::OriginalName("CAM_TARGET_ATTACKER_GROUND")] CamTargetAttackerGround = 2,
-    [pbr::OriginalName("CAM_TARGET_DEFENDER")] CamTargetDefender = 3,
-    [pbr::OriginalName("CAM_TARGET_DEFENDER_EDGE")] CamTargetDefenderEdge = 4,
-    [pbr::OriginalName("CAM_TARGET_DEFENDER_GROUND")] CamTargetDefenderGround = 5,
-    [pbr::OriginalName("CAM_TARGET_ATTACKER_DEFENDER")] CamTargetAttackerDefender = 6,
-    [pbr::OriginalName("CAM_TARGET_ATTACKER_DEFENDER_EDGE")] CamTargetAttackerDefenderEdge = 7,
-    [pbr::OriginalName("CAM_TARGET_DEFENDER_ATTACKER")] CamTargetDefenderAttacker = 8,
-    [pbr::OriginalName("CAM_TARGET_DEFENDER_ATTACKER_EDGE")] CamTargetDefenderAttackerEdge = 9,
-    [pbr::OriginalName("CAM_TARGET_ATTACKER_DEFENDER_MIRROR")] CamTargetAttackerDefenderMirror = 11,
-    [pbr::OriginalName("CAM_TARGET_SHOULDER_ATTACKER_DEFENDER")] CamTargetShoulderAttackerDefender = 12,
-    [pbr::OriginalName("CAM_TARGET_SHOULDER_ATTACKER_DEFENDER_MIRROR")] CamTargetShoulderAttackerDefenderMirror = 13,
-    [pbr::OriginalName("CAM_TARGET_ATTACKER_DEFENDER_WORLD")] CamTargetAttackerDefenderWorld = 14,
-  }
-
-  public enum PokemonType {
-    [pbr::OriginalName("POKEMON_TYPE_NONE")] None = 0,
-    [pbr::OriginalName("POKEMON_TYPE_NORMAL")] Normal = 1,
-    [pbr::OriginalName("POKEMON_TYPE_FIGHTING")] Fighting = 2,
-    [pbr::OriginalName("POKEMON_TYPE_FLYING")] Flying = 3,
-    [pbr::OriginalName("POKEMON_TYPE_POISON")] Poison = 4,
-    [pbr::OriginalName("POKEMON_TYPE_GROUND")] Ground = 5,
-    [pbr::OriginalName("POKEMON_TYPE_ROCK")] Rock = 6,
-    [pbr::OriginalName("POKEMON_TYPE_BUG")] Bug = 7,
-    [pbr::OriginalName("POKEMON_TYPE_GHOST")] Ghost = 8,
-    [pbr::OriginalName("POKEMON_TYPE_STEEL")] Steel = 9,
-    [pbr::OriginalName("POKEMON_TYPE_FIRE")] Fire = 10,
-    [pbr::OriginalName("POKEMON_TYPE_WATER")] Water = 11,
-    [pbr::OriginalName("POKEMON_TYPE_GRASS")] Grass = 12,
-    [pbr::OriginalName("POKEMON_TYPE_ELECTRIC")] Electric = 13,
-    [pbr::OriginalName("POKEMON_TYPE_PSYCHIC")] Psychic = 14,
-    [pbr::OriginalName("POKEMON_TYPE_ICE")] Ice = 15,
-    [pbr::OriginalName("POKEMON_TYPE_DRAGON")] Dragon = 16,
-    [pbr::OriginalName("POKEMON_TYPE_DARK")] Dark = 17,
-    [pbr::OriginalName("POKEMON_TYPE_FAIRY")] Fairy = 18,
-  }
-
-  public enum PokemonMovementType {
-    [pbr::OriginalName("MOVEMENT_STATIC")] MovementStatic = 0,
-    [pbr::OriginalName("MOVEMENT_JUMP")] MovementJump = 1,
-    [pbr::OriginalName("MOVEMENT_VERTICAL")] MovementVertical = 2,
-    [pbr::OriginalName("MOVEMENT_PSYCHIC")] MovementPsychic = 3,
-    [pbr::OriginalName("MOVEMENT_ELECTRIC")] MovementElectric = 4,
-    [pbr::OriginalName("MOVEMENT_FLYING")] MovementFlying = 5,
-    [pbr::OriginalName("MOVEMENT_HOVERING")] MovementHovering = 6,
-  }
-
-  public enum PokemonClass {
-    [pbr::OriginalName("NORMAL")] Normal = 0,
-    [pbr::OriginalName("LEGENDARY")] Legendary = 1,
-    [pbr::OriginalName("MYTHIC")] Mythic = 2,
-  }
-
-  #endregion
-
-}
-
-#endregion Designer generated code
diff --git a/PokemonGo.RocketAPI/GeneratedCode/Payloads.cs b/PokemonGo.RocketAPI/GeneratedCode/Payloads.cs
deleted file mode 100644
index fe2678d..0000000
--- a/PokemonGo.RocketAPI/GeneratedCode/Payloads.cs
+++ /dev/null
@@ -1,27630 +0,0 @@
-#pragma warning disable 1591, 0612, 3021
-
-#region Designer generated code
-
-#region
-
-using pb = global::Google.Protobuf;
-using pbc = global::Google.Protobuf.Collections;
-using pbr = global::Google.Protobuf.Reflection;
-using scg = global::System.Collections.Generic;
-
-#endregion
-
-namespace PokemonGo.RocketAPI.GeneratedCode
-{
-    /// <summary>Holder for reflection information generated from Payloads.proto</summary>
-    [global::System.Diagnostics.DebuggerNonUserCodeAttribute()]
-    public static partial class PayloadsReflection
-    {
-        #region Descriptor
-
-        /// <summary>File descriptor for Payloads.proto</summary>
-        public static pbr::FileDescriptor Descriptor
-        {
-            get { return descriptor; }
-        }
-
-        private static pbr::FileDescriptor descriptor;
-
-        static PayloadsReflection()
-        {
-            var descriptorData = global::System.Convert.FromBase64String(
-                string.Concat(
-                    "Cg5QYXlsb2Fkcy5wcm90bxIhUG9rZW1vbkdvLlJvY2tldEFQSS5HZW5lcmF0",
-                    "ZWRDb2RlGg1BbGxFbnVtLnByb3RvImIKEUdldFBsYXllclJlc3BvbnNlEhAK",
-                    "CHVua25vd24xGAEgASgFEjsKB3Byb2ZpbGUYAiABKAsyKi5Qb2tlbW9uR28u",
-                    "Um9ja2V0QVBJLkdlbmVyYXRlZENvZGUuUHJvZmlsZSL9AgoHUHJvZmlsZRIV",
-                    "Cg1jcmVhdGlvbl90aW1lGAEgASgDEhAKCHVzZXJuYW1lGAIgASgJEiAKBHRl",
-                    "YW0YBSABKA4yEi5BbGxFbnVtLlRlYW1Db2xvchIQCgh0dXRvcmlhbBgHIAEo",
-                    "DBJACgZhdmF0YXIYCCABKAsyMC5Qb2tlbW9uR28uUm9ja2V0QVBJLkdlbmVy",
-                    "YXRlZENvZGUuQXZhdGFyRGV0YWlscxIUCgxwb2tlX3N0b3JhZ2UYCSABKAUS",
-                    "FAoMaXRlbV9zdG9yYWdlGAogASgFEkIKC2RhaWx5X2JvbnVzGAsgASgLMi0u",
-                    "UG9rZW1vbkdvLlJvY2tldEFQSS5HZW5lcmF0ZWRDb2RlLkRhaWx5Qm9udXMS",
-                    "EQoJdW5rbm93bjEyGAwgASgMEhEKCXVua25vd24xMxgNIAEoDBI9CghjdXJy",
-                    "ZW5jeRgOIAMoCzIrLlBva2Vtb25Hby5Sb2NrZXRBUEkuR2VuZXJhdGVkQ29k",
-                    "ZS5DdXJyZW5jeSJZCgpEYWlseUJvbnVzEh4KFk5leHRDb2xsZWN0VGltZXN0",
-                    "YW1wTXMYASABKAMSKwojTmV4dERlZmVuZGVyQm9udXNDb2xsZWN0VGltZXN0",
-                    "YW1wTXMYAiABKAMiKAoIQ3VycmVuY3kSDAoEdHlwZRgBIAEoCRIOCgZhbW91",
-                    "bnQYAiABKAUiWAoNQXZhdGFyRGV0YWlscxIQCgh1bmtub3duMhgCIAEoBRIQ",
-                    "Cgh1bmtub3duMxgDIAEoBRIQCgh1bmtub3duORgJIAEoBRIRCgl1bmtub3du",
-                    "MTAYCiABKAUiJwoXRG93bmxvYWRTZXR0aW5nc1JlcXVlc3QSDAoEaGFzaBgB",
-                    "IAEoCSJzChRHZXRJbnZlbnRvcnlSZXNwb25zZRIPCgdzdWNjZXNzGAEgASgI",
-                    "EkoKD2ludmVudG9yeV9kZWx0YRgCIAEoCzIxLlBva2Vtb25Hby5Sb2NrZXRB",
-                    "UEkuR2VuZXJhdGVkQ29kZS5JbnZlbnRvcnlEZWx0YSKUAQoOSW52ZW50b3J5",
-                    "RGVsdGESHQoVb3JpZ2luYWxfdGltZXN0YW1wX21zGAEgASgDEhgKEG5ld190",
-                    "aW1lc3RhbXBfbXMYAiABKAMSSQoPaW52ZW50b3J5X2l0ZW1zGAMgAygLMjAu",
-                    "UG9rZW1vbkdvLlJvY2tldEFQSS5HZW5lcmF0ZWRDb2RlLkludmVudG9yeUl0",
-                    "ZW0imwEKDUludmVudG9yeUl0ZW0SHQoVbW9kaWZpZWRfdGltZXN0YW1wX21z",
-                    "GAEgASgDEhgKEGRlbGV0ZWRfaXRlbV9rZXkYAiABKAMSUQoTaW52ZW50b3J5",
-                    "X2l0ZW1fZGF0YRgDIAEoCzI0LlBva2Vtb25Hby5Sb2NrZXRBUEkuR2VuZXJh",
-                    "dGVkQ29kZS5JbnZlbnRvcnlJdGVtRGF0YSLbBQoRSW52ZW50b3J5SXRlbURh",
-                    "dGESPwoHcG9rZW1vbhgBIAEoCzIuLlBva2Vtb25Hby5Sb2NrZXRBUEkuR2Vu",
-                    "ZXJhdGVkQ29kZS5Qb2tlbW9uRGF0YRI1CgRpdGVtGAIgASgLMicuUG9rZW1v",
-                    "bkdvLlJvY2tldEFQSS5HZW5lcmF0ZWRDb2RlLkl0ZW0SRgoNcG9rZWRleF9l",
-                    "bnRyeRgDIAEoCzIvLlBva2Vtb25Hby5Sb2NrZXRBUEkuR2VuZXJhdGVkQ29k",
-                    "ZS5Qb2tlZGV4RW50cnkSRAoMcGxheWVyX3N0YXRzGAQgASgLMi4uUG9rZW1v",
-                    "bkdvLlJvY2tldEFQSS5HZW5lcmF0ZWRDb2RlLlBsYXllclN0YXRzEkoKD3Bs",
-                    "YXllcl9jdXJyZW5jeRgFIAEoCzIxLlBva2Vtb25Hby5Sb2NrZXRBUEkuR2Vu",
-                    "ZXJhdGVkQ29kZS5QbGF5ZXJDdXJyZW5jeRJGCg1wbGF5ZXJfY2FtZXJhGAYg",
-                    "ASgLMi8uUG9rZW1vbkdvLlJvY2tldEFQSS5HZW5lcmF0ZWRDb2RlLlBsYXll",
-                    "ckNhbWVyYRJQChJpbnZlbnRvcnlfdXBncmFkZXMYByABKAsyNC5Qb2tlbW9u",
-                    "R28uUm9ja2V0QVBJLkdlbmVyYXRlZENvZGUuSW52ZW50b3J5VXBncmFkZXMS",
-                    "RgoNYXBwbGllZF9pdGVtcxgIIAEoCzIvLlBva2Vtb25Hby5Sb2NrZXRBUEku",
-                    "R2VuZXJhdGVkQ29kZS5BcHBsaWVkSXRlbXMSSAoOZWdnX2luY3ViYXRvcnMY",
-                    "CSABKAsyMC5Qb2tlbW9uR28uUm9ja2V0QVBJLkdlbmVyYXRlZENvZGUuRWdn",
-                    "SW5jdWJhdG9ycxJICg5wb2tlbW9uX2ZhbWlseRgKIAEoCzIwLlBva2Vtb25H",
-                    "by5Sb2NrZXRBUEkuR2VuZXJhdGVkQ29kZS5Qb2tlbW9uRmFtaWx5IkcKFFJl",
-                    "Y3ljbGVJbnZlbnRvcnlJdGVtEiAKB2l0ZW1faWQYASABKA4yDy5BbGxFbnVt",
-                    "Lkl0ZW1JZBINCgVjb3VudBgCIAEoBSLYBQoHUG9rZW1vbhIKCgJpZBgBIAEo",
-                    "BRIoCgxwb2tlbW9uX3R5cGUYAiABKA4yEi5BbGxFbnVtLlBva2Vtb25JZBIK",
-                    "CgJjcBgDIAEoBRIPCgdzdGFtaW5hGAQgASgFEhMKC3N0YW1pbmFfbWF4GAUg",
-                    "ASgFEiQKBm1vdmVfMRgGIAEoDjIULkFsbEVudW0uUG9rZW1vbk1vdmUSJAoG",
-                    "bW92ZV8yGAcgASgOMhQuQWxsRW51bS5Qb2tlbW9uTW92ZRIYChBkZXBsb3ll",
-                    "ZF9mb3J0X2lkGAggASgFEhIKCm93bmVyX25hbWUYCSABKAkSDgoGaXNfZWdn",
-                    "GAogASgIEhwKFGVnZ19rbV93YWxrZWRfdGFyZ2V0GAsgASgFEhsKE2VnZ19r",
-                    "bV93YWxrZWRfc3RhcnQYDCABKAUSDgoGb3JpZ2luGA4gASgFEhAKCGhlaWdo",
-                    "dF9tGA8gASgCEhEKCXdlaWdodF9rZxgQIAEoAhIZChFpbmRpdmlkdWFsX2F0",
-                    "dGFjaxgRIAEoBRIaChJpbmRpdmlkdWFsX2RlZmVuc2UYEiABKAUSGgoSaW5k",
-                    "aXZpZHVhbF9zdGFtaW5hGBMgASgFEhUKDWNwX211bHRpcGxpZXIYFCABKAUS",
-                    "EAoIcG9rZWJhbGwYFSABKAUSGAoQY2FwdHVyZWRfY2VsbF9pZBgWIAEoBBIY",
-                    "ChBiYXR0bGVzX2F0dGFja2VkGBcgASgFEhgKEGJhdHRsZXNfZGVmZW5kZWQY",
-                    "GCABKAUSGAoQZWdnX2luY3ViYXRvcl9pZBgZIAEoBRIYChBjcmVhdGlvbl90",
-                    "aW1lX21zGBogASgEEhQKDG51bV91cGdyYWRlcxgbIAEoBRIgChhhZGRpdGlv",
-                    "bmFsX2NwX211bHRpcGxpZXIYHCABKAUSEAoIZmF2b3JpdGUYHSABKAUSEAoI",
-                    "bmlja25hbWUYHiABKAkSEQoJZnJvbV9mb3J0GB8gASgFIkYKBEl0ZW0SHwoE",
-                    "aXRlbRgBIAEoDjIRLkFsbEVudW0uSXRlbVR5cGUSDQoFY291bnQYAiABKAUS",
-                    "DgoGdW5zZWVuGAMgASgIIpkBCgxQb2tlZGV4RW50cnkSHAoUcG9rZWRleF9l",
-                    "bnRyeV9udW1iZXIYASABKAUSGQoRdGltZXNfZW5jb3VudGVyZWQYAiABKAUS",
-                    "FgoOdGltZXNfY2FwdHVyZWQYAyABKAUSHgoWZXZvbHV0aW9uX3N0b25lX3Bp",
-                    "ZWNlcxgEIAEoBRIYChBldm9sdXRpb25fc3RvbmVzGAUgASgFIu0ECgtQbGF5",
-                    "ZXJTdGF0cxINCgVsZXZlbBgBIAEoBRISCgpleHBlcmllbmNlGAIgASgDEhUK",
-                    "DXByZXZfbGV2ZWxfeHAYAyABKAMSFQoNbmV4dF9sZXZlbF94cBgEIAEoAxIR",
-                    "CglrbV93YWxrZWQYBSABKAISHAoUcG9rZW1vbnNfZW5jb3VudGVyZWQYBiAB",
-                    "KAUSHgoWdW5pcXVlX3Bva2VkZXhfZW50cmllcxgHIAEoBRIZChFwb2tlbW9u",
-                    "c19jYXB0dXJlZBgIIAEoBRISCgpldm9sdXRpb25zGAkgASgFEhgKEHBva2Vf",
-                    "c3RvcF92aXNpdHMYCiABKAUSGAoQcG9rZWJhbGxzX3Rocm93bhgLIAEoBRIU",
-                    "CgxlZ2dzX2hhdGNoZWQYDCABKAUSGwoTYmlnX21hZ2lrYXJwX2NhdWdodBgN",
-                    "IAEoBRIZChFiYXR0bGVfYXR0YWNrX3dvbhgOIAEoBRIbChNiYXR0bGVfYXR0",
-                    "YWNrX3RvdGFsGA8gASgFEhsKE2JhdHRsZV9kZWZlbmRlZF93b24YECABKAUS",
-                    "GwoTYmF0dGxlX3RyYWluaW5nX3dvbhgRIAEoBRIdChViYXR0bGVfdHJhaW5p",
-                    "bmdfdG90YWwYEiABKAUSHQoVcHJlc3RpZ2VfcmFpc2VkX3RvdGFsGBMgASgF",
-                    "Eh4KFnByZXN0aWdlX2Ryb3BwZWRfdG90YWwYFCABKAUSGAoQcG9rZW1vbl9k",
-                    "ZXBsb3llZBgVIAEoBRIeChZwb2tlbW9uX2NhdWdodF9ieV90eXBlGBYgASgM",
-                    "EhwKFHNtYWxsX3JhdHRhdGFfY2F1Z2h0GBcgASgFIh4KDlBsYXllckN1cnJl",
-                    "bmN5EgwKBGdlbXMYASABKAUiKQoMUGxheWVyQ2FtZXJhEhkKEWlzX2RlZmF1",
-                    "bHRfY2FtZXJhGAEgASgIImQKEUludmVudG9yeVVwZ3JhZGVzEk8KEmludmVu",
-                    "dG9yeV91cGdyYWRlcxgBIAMoCzIzLlBva2Vtb25Hby5Sb2NrZXRBUEkuR2Vu",
-                    "ZXJhdGVkQ29kZS5JbnZlbnRvcnlVcGdyYWRlIoQBChBJbnZlbnRvcnlVcGdy",
-                    "YWRlEh8KBGl0ZW0YASABKA4yES5BbGxFbnVtLkl0ZW1UeXBlEjMKDHVwZ3Jh",
-                    "ZGVfdHlwZRgCIAEoDjIdLkFsbEVudW0uSW52ZW50b3J5VXBncmFkZVR5cGUS",
-                    "GgoSYWRkaXRpb25hbF9zdG9yYWdlGAMgASgFIkwKDEFwcGxpZWRJdGVtcxI8",
-                    "CgRpdGVtGAQgASgLMi4uUG9rZW1vbkdvLlJvY2tldEFQSS5HZW5lcmF0ZWRD",
-                    "b2RlLkFwcGxpZWRJdGVtIocBCgtBcHBsaWVkSXRlbRIiCglpdGVtX3R5cGUY",
-                    "ASABKA4yDy5BbGxFbnVtLkl0ZW1JZBItChJpdGVtX3R5cGVfY2F0ZWdvcnkY",
-                    "AiABKA4yES5BbGxFbnVtLkl0ZW1UeXBlEhEKCWV4cGlyZV9tcxgDIAEoAxIS",
-                    "CgphcHBsaWVkX21zGAQgASgDIlcKDUVnZ0luY3ViYXRvcnMSRgoNZWdnX2lu",
-                    "Y3ViYXRvchgBIAEoCzIvLlBva2Vtb25Hby5Sb2NrZXRBUEkuR2VuZXJhdGVk",
-                    "Q29kZS5FZ2dJbmN1YmF0b3Ii1wEKDEVnZ0luY3ViYXRvchIPCgdpdGVtX2lk",
-                    "GAEgASgJEiQKCWl0ZW1fdHlwZRgCIAEoDjIRLkFsbEVudW0uSXRlbVR5cGUS",
-                    "MQoOaW5jdWJhdG9yX3R5cGUYAyABKA4yGS5BbGxFbnVtLkVnZ0luY3ViYXRv",
-                    "clR5cGUSFgoOdXNlc19yZW1haW5pbmcYBCABKAUSEgoKcG9rZW1vbl9pZBgF",
-                    "IAEoAxIXCg9zdGFydF9rbV93YWxrZWQYBiABKAESGAoQdGFyZ2V0X2ttX3dh",
-                    "bGtlZBgHIAEoASJLCg1Qb2tlbW9uRmFtaWx5EisKCWZhbWlseV9pZBgBIAEo",
-                    "DjIYLkFsbEVudW0uUG9rZW1vbkZhbWlseUlkEg0KBWNhbmR5GAIgASgFImgK",
-                    "FEdldE1hcE9iamVjdHNSZXF1ZXN0Eg8KB2NlbGxfaWQYASABKAwSGgoSc2lu",
-                    "Y2VfdGltZXN0YW1wX21zGAIgASgMEhAKCGxhdGl0dWRlGAMgASgBEhEKCWxv",
-                    "bmdpdHVkZRgEIAEoASKBAQoVR2V0TWFwT2JqZWN0c1Jlc3BvbnNlEj0KCW1h",
-                    "cF9jZWxscxgBIAMoCzIqLlBva2Vtb25Hby5Sb2NrZXRBUEkuR2VuZXJhdGVk",
-                    "Q29kZS5NYXBDZWxsEikKBnN0YXR1cxgCIAEoDjIZLkFsbEVudW0uTWFwT2Jq",
-                    "ZWN0c1N0YXR1cyLkBAoHTWFwQ2VsbBISCgpzMl9jZWxsX2lkGAEgASgEEhwK",
-                    "FGN1cnJlbnRfdGltZXN0YW1wX21zGAIgASgDEjoKBWZvcnRzGAMgAygLMisu",
-                    "UG9rZW1vbkdvLlJvY2tldEFQSS5HZW5lcmF0ZWRDb2RlLkZvcnREYXRhEkMK",
-                    "DHNwYXduX3BvaW50cxgEIAMoCzItLlBva2Vtb25Hby5Sb2NrZXRBUEkuR2Vu",
-                    "ZXJhdGVkQ29kZS5TcGF3blBvaW50EhcKD2RlbGV0ZWRfb2JqZWN0cxgGIAMo",
-                    "CRIZChFpc190cnVuY2F0ZWRfbGlzdBgHIAEoCBJGCg5mb3J0X3N1bW1hcmll",
-                    "cxgIIAMoCzIuLlBva2Vtb25Hby5Sb2NrZXRBUEkuR2VuZXJhdGVkQ29kZS5G",
-                    "b3J0U3VtbWFyeRJNChZkZWNpbWF0ZWRfc3Bhd25fcG9pbnRzGAkgAygLMi0u",
-                    "UG9rZW1vbkdvLlJvY2tldEFQSS5HZW5lcmF0ZWRDb2RlLlNwYXduUG9pbnQS",
-                    "RQoNd2lsZF9wb2tlbW9ucxgFIAMoCzIuLlBva2Vtb25Hby5Sb2NrZXRBUEku",
-                    "R2VuZXJhdGVkQ29kZS5XaWxkUG9rZW1vbhJJChJjYXRjaGFibGVfcG9rZW1v",
-                    "bnMYCiADKAsyLS5Qb2tlbW9uR28uUm9ja2V0QVBJLkdlbmVyYXRlZENvZGUu",
-                    "TWFwUG9rZW1vbhJJCg9uZWFyYnlfcG9rZW1vbnMYCyADKAsyMC5Qb2tlbW9u",
-                    "R28uUm9ja2V0QVBJLkdlbmVyYXRlZENvZGUuTmVhcmJ5UG9rZW1vbiKTBAoI",
-                    "Rm9ydERhdGESCgoCaWQYASABKAkSIgoabGFzdF9tb2RpZmllZF90aW1lc3Rh",
-                    "bXBfbXMYAiABKAMSEAoIbGF0aXR1ZGUYAyABKAESEQoJbG9uZ2l0dWRlGAQg",
-                    "ASgBEg8KB2VuYWJsZWQYCCABKAgSHwoEdHlwZRgJIAEoDjIRLkFsbEVudW0u",
-                    "Rm9ydFR5cGUSKQoNb3duZWRfYnlfdGVhbRgFIAEoDjISLkFsbEVudW0uVGVh",
-                    "bUNvbG9yEiwKEGd1YXJkX3Bva2Vtb25faWQYBiABKA4yEi5BbGxFbnVtLlBv",
-                    "a2Vtb25JZBIYChBndWFyZF9wb2tlbW9uX2NwGAcgASgFEhIKCmd5bV9wb2lu",
-                    "dHMYCiABKAMSFAoMaXNfaW5fYmF0dGxlGAsgASgIEiYKHmNvb2xkb3duX2Nv",
-                    "bXBsZXRlX3RpbWVzdGFtcF9tcxgOIAEoAxIlCgdzcG9uc29yGA8gASgOMhQu",
-                    "QWxsRW51bS5Gb3J0U3BvbnNvchIyCg5yZW5kZXJpbmdfdHlwZRgQIAEoDjIa",
-                    "LkFsbEVudW0uRm9ydFJlbmRlcmluZ1R5cGUSHAoUYWN0aXZlX2ZvcnRfbW9k",
-                    "aWZpZXIYDCABKAwSQgoJbHVyZV9pbmZvGA0gASgLMi8uUG9rZW1vbkdvLlJv",
-                    "Y2tldEFQSS5HZW5lcmF0ZWRDb2RlLkZvcnRMdXJlSW5mbyKDAQoMRm9ydEx1",
-                    "cmVJbmZvEg8KB2ZvcnRfaWQYASABKAkSEAoIdW5rbm93bjIYAiABKAESLQoR",
-                    "YWN0aXZlX3Bva2Vtb25faWQYAyABKA4yEi5BbGxFbnVtLlBva2Vtb25JZBIh",
-                    "ChlsdXJlX2V4cGlyZXNfdGltZXN0YW1wX21zGAQgASgDIjEKClNwYXduUG9p",
-                    "bnQSEAoIbGF0aXR1ZGUYAiABKAESEQoJbG9uZ2l0dWRlGAMgASgBIm8KC0Zv",
-                    "cnRTdW1tYXJ5EhcKD2ZvcnRfc3VtbWFyeV9pZBgBIAEoBRIiChpsYXN0X21v",
-                    "ZGlmaWVkX3RpbWVzdGFtcF9tcxgCIAEoBRIQCghsYXRpdHVkZRgDIAEoBRIR",
-                    "Cglsb25naXR1ZGUYBCABKAUi5gEKC1dpbGRQb2tlbW9uEhQKDGVuY291bnRl",
-                    "cl9pZBgBIAEoBhIiChpsYXN0X21vZGlmaWVkX3RpbWVzdGFtcF9tcxgCIAEo",
-                    "AxIQCghsYXRpdHVkZRgDIAEoARIRCglsb25naXR1ZGUYBCABKAESFQoNc3Bh",
-                    "d25wb2ludF9pZBgFIAEoCRJECgxwb2tlbW9uX2RhdGEYByABKAsyLi5Qb2tl",
-                    "bW9uR28uUm9ja2V0QVBJLkdlbmVyYXRlZENvZGUuUG9rZW1vbkRhdGESGwoT",
-                    "dGltZV90aWxsX2hpZGRlbl9tcxgLIAEoBSLaBQoLUG9rZW1vbkRhdGESCgoC",
-                    "aWQYASABKAYSJgoKcG9rZW1vbl9pZBgCIAEoDjISLkFsbEVudW0uUG9rZW1v",
-                    "bklkEgoKAmNwGAMgASgFEg8KB3N0YW1pbmEYBCABKAUSEwoLc3RhbWluYV9t",
-                    "YXgYBSABKAUSJAoGbW92ZV8xGAYgASgOMhQuQWxsRW51bS5Qb2tlbW9uTW92",
-                    "ZRIkCgZtb3ZlXzIYByABKA4yFC5BbGxFbnVtLlBva2Vtb25Nb3ZlEhgKEGRl",
-                    "cGxveWVkX2ZvcnRfaWQYCCABKAUSEgoKb3duZXJfbmFtZRgJIAEoCRIOCgZp",
-                    "c19lZ2cYCiABKAgSHAoUZWdnX2ttX3dhbGtlZF90YXJnZXQYCyABKAUSGwoT",
-                    "ZWdnX2ttX3dhbGtlZF9zdGFydBgMIAEoBRIOCgZvcmlnaW4YDiABKAUSEAoI",
-                    "aGVpZ2h0X20YDyABKAISEQoJd2VpZ2h0X2tnGBAgASgCEhkKEWluZGl2aWR1",
-                    "YWxfYXR0YWNrGBEgASgFEhoKEmluZGl2aWR1YWxfZGVmZW5zZRgSIAEoBRIa",
-                    "ChJpbmRpdmlkdWFsX3N0YW1pbmEYEyABKAUSFQoNY3BfbXVsdGlwbGllchgU",
-                    "IAEoBRIQCghwb2tlYmFsbBgVIAEoBRIYChBjYXB0dXJlZF9jZWxsX2lkGBYg",
-                    "ASgEEhgKEGJhdHRsZXNfYXR0YWNrZWQYFyABKAUSGAoQYmF0dGxlc19kZWZl",
-                    "bmRlZBgYIAEoBRIYChBlZ2dfaW5jdWJhdG9yX2lkGBkgASgFEhgKEGNyZWF0",
-                    "aW9uX3RpbWVfbXMYGiABKAQSFAoMbnVtX3VwZ3JhZGVzGBsgASgFEiAKGGFk",
-                    "ZGl0aW9uYWxfY3BfbXVsdGlwbGllchgcIAEoBRIQCghmYXZvcml0ZRgdIAEo",
-                    "BRIQCghuaWNrbmFtZRgeIAEoCRIRCglmcm9tX2ZvcnQYHyABKAUipwEKCk1h",
-                    "cFBva2Vtb24SFQoNc3Bhd25wb2ludF9pZBgBIAEoCRIUCgxlbmNvdW50ZXJf",
-                    "aWQYAiABKAYSJgoKcG9rZW1vbl9pZBgDIAEoDjISLkFsbEVudW0uUG9rZW1v",
-                    "bklkEh8KF2V4cGlyYXRpb25fdGltZXN0YW1wX21zGAQgASgDEhAKCGxhdGl0",
-                    "dWRlGAUgASgBEhEKCWxvbmdpdHVkZRgGIAEoASJpCg1OZWFyYnlQb2tlbW9u",
-                    "EiYKCnBva2Vtb25faWQYASABKA4yEi5BbGxFbnVtLlBva2Vtb25JZBIaChJk",
-                    "aXN0YW5jZV9pbl9tZXRlcnMYAiABKAISFAoMZW5jb3VudGVyX2lkGAMgASgG",
-                    "InwKGERvd25sb2FkU2V0dGluZ3NSZXNwb25zZRINCgVlcnJvchgBIAEoCRIM",
-                    "CgRoYXNoGAIgASgJEkMKCHNldHRpbmdzGAMgASgLMjEuUG9rZW1vbkdvLlJv",
-                    "Y2tldEFQSS5HZW5lcmF0ZWRDb2RlLkdsb2JhbFNldHRpbmdzItoCCg5HbG9i",
-                    "YWxTZXR0aW5ncxJGCg1mb3J0X3NldHRpbmdzGAIgASgLMi8uUG9rZW1vbkdv",
-                    "LlJvY2tldEFQSS5HZW5lcmF0ZWRDb2RlLkZvcnRTZXR0aW5ncxJECgxtYXBf",
-                    "c2V0dGluZ3MYAyABKAsyLi5Qb2tlbW9uR28uUm9ja2V0QVBJLkdlbmVyYXRl",
-                    "ZENvZGUuTWFwU2V0dGluZ3MSSAoObGV2ZWxfc2V0dGluZ3MYBCABKAsyMC5Q",
-                    "b2tlbW9uR28uUm9ja2V0QVBJLkdlbmVyYXRlZENvZGUuTGV2ZWxTZXR0aW5n",
-                    "cxJQChJpbnZlbnRvcnlfc2V0dGluZ3MYBSABKAsyNC5Qb2tlbW9uR28uUm9j",
-                    "a2V0QVBJLkdlbmVyYXRlZENvZGUuSW52ZW50b3J5U2V0dGluZ3MSHgoWbWlu",
-                    "aW11bV9jbGllbnRfdmVyc2lvbhgGIAEoCSLkAQoMRm9ydFNldHRpbmdzEiAK",
-                    "GGludGVyYWN0aW9uX3JhbmdlX21ldGVycxgBIAEoARIiChptYXhfdG90YWxf",
-                    "ZGVwbG95ZWRfcG9rZW1vbhgCIAEoBRIjChttYXhfcGxheWVyX2RlcGxveWVk",
-                    "X3Bva2Vtb24YAyABKAUSIQoZZGVwbG95X3N0YW1pbmFfbXVsdGlwbGllchgE",
-                    "IAEoARIgChhkZXBsb3lfYXR0YWNrX211bHRpcGxpZXIYBSABKAESJAocZmFy",
-                    "X2ludGVyYWN0aW9uX3JhbmdlX21ldGVycxgGIAEoASKPAgoLTWFwU2V0dGlu",
-                    "Z3MSHQoVcG9rZW1vbl92aXNpYmxlX3JhbmdlGAEgASgBEh0KFXBva2VfbmF2",
-                    "X3JhbmdlX21ldGVycxgCIAEoARIeChZlbmNvdW50ZXJfcmFuZ2VfbWV0ZXJz",
-                    "GAMgASgBEisKI2dldF9tYXBfb2JqZWN0c19taW5fcmVmcmVzaF9zZWNvbmRz",
-                    "GAQgASgCEisKI2dldF9tYXBfb2JqZWN0c19tYXhfcmVmcmVzaF9zZWNvbmRz",
-                    "GAUgASgCEisKI2dldF9tYXBfb2JqZWN0c19taW5fZGlzdGFuY2VfbWV0ZXJz",
-                    "GAYgASgCEhsKE2dvb2dsZV9tYXBzX2FwaV9rZXkYByABKAkiUQoNTGV2ZWxT",
-                    "ZXR0aW5ncxIbChN0cmFpbmVyX2NwX21vZGlmaWVyGAIgASgBEiMKG3RyYWlu",
-                    "ZXJfZGlmZmljdWx0eV9tb2RpZmllchgDIAEoASKAAQoRSW52ZW50b3J5U2V0",
-                    "dGluZ3MSEwoLbWF4X3Bva2Vtb24YASABKAUSFQoNbWF4X2JhZ19pdGVtcxgC",
-                    "IAEoBRIUCgxiYXNlX3Bva2Vtb24YAyABKAUSFgoOYmFzZV9iYWdfaXRlbXMY",
-                    "BCABKAUSEQoJYmFzZV9lZ2dzGAUgASgFIjoKE1BsYXllclVwZGF0ZVJlcXVl",
-                    "c3QSEAoIbGF0aXR1ZGUYASABKAESEQoJbG9uZ2l0dWRlGAIgASgBIq8BChRQ",
-                    "bGF5ZXJVcGRhdGVSZXNwb25zZRJFCg13aWxkX3Bva2Vtb25zGAEgAygLMi4u",
-                    "UG9rZW1vbkdvLlJvY2tldEFQSS5HZW5lcmF0ZWRDb2RlLldpbGRQb2tlbW9u",
-                    "EjoKBWZvcnRzGAIgAygLMisuUG9rZW1vbkdvLlJvY2tldEFQSS5HZW5lcmF0",
-                    "ZWRDb2RlLkZvcnREYXRhEhQKDGZvcnRzX25lYXJieRgDIAEoBSIeChxEb3du",
-                    "bG9hZEl0ZW1UZW1wbGF0ZXNSZXF1ZXN0ItsKCh1Eb3dubG9hZEl0ZW1UZW1w",
-                    "bGF0ZXNSZXNwb25zZRIPCgdzdWNjZXNzGAEgASgIEmUKDml0ZW1fdGVtcGxh",
-                    "dGVzGAIgAygLMk0uUG9rZW1vbkdvLlJvY2tldEFQSS5HZW5lcmF0ZWRDb2Rl",
-                    "LkRvd25sb2FkSXRlbVRlbXBsYXRlc1Jlc3BvbnNlLkl0ZW1UZW1wbGF0ZRIU",
-                    "Cgx0aW1lc3RhbXBfbXMYAyABKAQaqwkKDEl0ZW1UZW1wbGF0ZRITCgt0ZW1w",
-                    "bGF0ZV9pZBgBIAEoCRJMChBwb2tlbW9uX3NldHRpbmdzGAIgASgLMjIuUG9r",
-                    "ZW1vbkdvLlJvY2tldEFQSS5HZW5lcmF0ZWRDb2RlLlBva2Vtb25TZXR0aW5n",
-                    "cxJGCg1pdGVtX3NldHRpbmdzGAMgASgLMi8uUG9rZW1vbkdvLlJvY2tldEFQ",
-                    "SS5HZW5lcmF0ZWRDb2RlLkl0ZW1TZXR0aW5ncxJGCg1tb3ZlX3NldHRpbmdz",
-                    "GAQgASgLMi8uUG9rZW1vbkdvLlJvY2tldEFQSS5HZW5lcmF0ZWRDb2RlLk1v",
-                    "dmVTZXR0aW5ncxJXChZtb3ZlX3NlcXVlbmNlX3NldHRpbmdzGAUgASgLMjcu",
-                    "UG9rZW1vbkdvLlJvY2tldEFQSS5HZW5lcmF0ZWRDb2RlLk1vdmVTZXF1ZW5j",
-                    "ZVNldHRpbmdzElAKDnR5cGVfZWZmZWN0aXZlGAggASgLMjguUG9rZW1vbkdv",
-                    "LlJvY2tldEFQSS5HZW5lcmF0ZWRDb2RlLlR5cGVFZmZlY3RpdmVTZXR0aW5n",
-                    "cxJICg5iYWRnZV9zZXR0aW5ncxgKIAEoCzIwLlBva2Vtb25Hby5Sb2NrZXRB",
-                    "UEkuR2VuZXJhdGVkQ29kZS5CYWRnZVNldHRpbmdzEkEKBmNhbWVyYRgLIAEo",
-                    "CzIxLlBva2Vtb25Hby5Sb2NrZXRBUEkuR2VuZXJhdGVkQ29kZS5DYW1lcmFT",
-                    "ZXR0aW5ncxJMCgxwbGF5ZXJfbGV2ZWwYDCABKAsyNi5Qb2tlbW9uR28uUm9j",
-                    "a2V0QVBJLkdlbmVyYXRlZENvZGUuUGxheWVyTGV2ZWxTZXR0aW5ncxJGCgln",
-                    "eW1fbGV2ZWwYDSABKAsyMy5Qb2tlbW9uR28uUm9ja2V0QVBJLkdlbmVyYXRl",
-                    "ZENvZGUuR3ltTGV2ZWxTZXR0aW5ncxJNCg9iYXR0bGVfc2V0dGluZ3MYDiAB",
-                    "KAsyNC5Qb2tlbW9uR28uUm9ja2V0QVBJLkdlbmVyYXRlZENvZGUuR3ltQmF0",
-                    "dGxlU2V0dGluZ3MSUAoSZW5jb3VudGVyX3NldHRpbmdzGA8gASgLMjQuUG9r",
-                    "ZW1vbkdvLlJvY2tldEFQSS5HZW5lcmF0ZWRDb2RlLkVuY291bnRlclNldHRp",
-                    "bmdzEksKEGlhcF9pdGVtX2Rpc3BsYXkYECABKAsyMS5Qb2tlbW9uR28uUm9j",
-                    "a2V0QVBJLkdlbmVyYXRlZENvZGUuSWFwSXRlbURpc3BsYXkSRAoMaWFwX3Nl",
-                    "dHRpbmdzGBEgASgLMi4uUG9rZW1vbkdvLlJvY2tldEFQSS5HZW5lcmF0ZWRD",
-                    "b2RlLklhcFNldHRpbmdzElMKEHBva2Vtb25fdXBncmFkZXMYEiABKAsyOS5Q",
-                    "b2tlbW9uR28uUm9ja2V0QVBJLkdlbmVyYXRlZENvZGUuUG9rZW1vblVwZ3Jh",
-                    "ZGVTZXR0aW5ncxJRCg9lcXVpcHBlZF9iYWRnZXMYEyABKAsyOC5Qb2tlbW9u",
-                    "R28uUm9ja2V0QVBJLkdlbmVyYXRlZENvZGUuRXF1aXBwZWRCYWRnZVNldHRp",
-                    "bmdzImkKFVVzZUl0ZW1DYXB0dXJlUmVxdWVzdBIgCgdpdGVtX2lkGAEgASgO",
-                    "Mg8uQWxsRW51bS5JdGVtSWQSFAoMZW5jb3VudGVyX2lkGAIgASgGEhgKEHNw",
-                    "YXduX3BvaW50X2d1aWQYAyABKAkisQEKFlVzZUl0ZW1DYXB0dXJlUmVzcG9u",
-                    "c2USDwoHc3VjY2VzcxgBIAEoCBIZChFpdGVtX2NhcHR1cmVfbXVsdBgCIAEo",
-                    "ARIWCg5pdGVtX2ZsZWVfbXVsdBgDIAEoARIVCg1zdG9wX21vdmVtZW50GAQg",
-                    "ASgIEhMKC3N0b3BfYXR0YWNrGAUgASgIEhIKCnRhcmdldF9tYXgYBiABKAgS",
-                    "EwoLdGFyZ2V0X3Nsb3cYByABKAgiKwoVUmVsZWFzZVBva2Vtb25SZXF1ZXN0",
-                    "EhIKCnBva2Vtb25faWQYASABKAYi3wEKFlJlbGVhc2VQb2tlbW9uUmVzcG9u",
-                    "c2USUAoGcmVzdWx0GAEgASgOMkAuUG9rZW1vbkdvLlJvY2tldEFQSS5HZW5l",
-                    "cmF0ZWRDb2RlLlJlbGVhc2VQb2tlbW9uUmVzcG9uc2UuUmVzdWx0EhUKDWNh",
-                    "bmR5X2F3YXJkZWQYAiABKAUiXAoGUmVzdWx0EgkKBVVOU0VUEAASCwoHU1VD",
-                    "Q0VTUxABEhQKEFBPS0VNT05fREVQTE9ZRUQQAhIKCgZGQUlMRUQQAxIYChRF",
-                    "UlJPUl9QT0tFTU9OX0lTX0VHRxAEIhcKFUdldEhhdGNoZWRFZ2dzUmVxdWVz",
-                    "dCKOAQoWR2V0SGF0Y2hlZEVnZ3NSZXNwb25zZRIPCgdzdWNjZXNzGAEgASgI",
-                    "EhYKCnBva2Vtb25faWQYAiADKARCAhABEhoKEmV4cGVyaWVuY2VfYXdhcmRl",
-                    "ZBgDIAMoBRIVCg1jYW5keV9hd2FyZGVkGAQgAygFEhgKEHN0YXJkdXN0X2F3",
-                    "YXJkZWQYBSADKAUihgEKEUZvcnRTZWFyY2hSZXF1ZXN0Eg8KB2ZvcnRfaWQY",
-                    "ASABKAkSFwoPcGxheWVyX2xhdGl0dWRlGAIgASgBEhgKEHBsYXllcl9sb25n",
-                    "aXR1ZGUYAyABKAESFQoNZm9ydF9sYXRpdHVkZRgEIAEoARIWCg5mb3J0X2xv",
-                    "bmdpdHVkZRgFIAEoASKtBAoSRm9ydFNlYXJjaFJlc3BvbnNlEkwKBnJlc3Vs",
-                    "dBgBIAEoDjI8LlBva2Vtb25Hby5Sb2NrZXRBUEkuR2VuZXJhdGVkQ29kZS5G",
-                    "b3J0U2VhcmNoUmVzcG9uc2UuUmVzdWx0ElYKDWl0ZW1zX2F3YXJkZWQYAiAD",
-                    "KAsyPy5Qb2tlbW9uR28uUm9ja2V0QVBJLkdlbmVyYXRlZENvZGUuRm9ydFNl",
-                    "YXJjaFJlc3BvbnNlLkl0ZW1Bd2FyZBIUCgxnZW1zX2F3YXJkZWQYAyABKAUS",
-                    "SAoQcG9rZW1vbl9kYXRhX2VnZxgEIAEoCzIuLlBva2Vtb25Hby5Sb2NrZXRB",
-                    "UEkuR2VuZXJhdGVkQ29kZS5Qb2tlbW9uRGF0YRIaChJleHBlcmllbmNlX2F3",
-                    "YXJkZWQYBSABKAUSJgoeY29vbGRvd25fY29tcGxldGVfdGltZXN0YW1wX21z",
-                    "GAYgASgDEiIKGmNoYWluX2hhY2tfc2VxdWVuY2VfbnVtYmVyGAcgASgFGkEK",
-                    "CUl0ZW1Bd2FyZBIgCgdpdGVtX2lkGAEgASgOMg8uQWxsRW51bS5JdGVtSWQS",
-                    "EgoKaXRlbV9jb3VudBgCIAEoBSJmCgZSZXN1bHQSEQoNTk9fUkVTVUxUX1NF",
-                    "VBAAEgsKB1NVQ0NFU1MQARIQCgxPVVRfT0ZfUkFOR0UQAhIWChJJTl9DT09M",
-                    "RE9XTl9QRVJJT0QQAxISCg5JTlZFTlRPUllfRlVMTBAEIkoKEkZvcnREZXRh",
-                    "aWxzUmVxdWVzdBIPCgdmb3J0X2lkGAEgASgJEhAKCGxhdGl0dWRlGAIgASgB",
-                    "EhEKCWxvbmdpdHVkZRgDIAEoASKHAwoTRm9ydERldGFpbHNSZXNwb25zZRIP",
-                    "Cgdmb3J0X2lkGAEgASgJEiYKCnRlYW1fY29sb3IYAiABKA4yEi5BbGxFbnVt",
-                    "LlRlYW1Db2xvchJECgxwb2tlbW9uX2RhdGEYAyABKAsyLi5Qb2tlbW9uR28u",
-                    "Um9ja2V0QVBJLkdlbmVyYXRlZENvZGUuUG9rZW1vbkRhdGESDAoEbmFtZRgE",
-                    "IAEoCRISCgppbWFnZV91cmxzGAUgAygJEgoKAmZwGAYgASgFEg8KB3N0YW1p",
-                    "bmEYByABKAUSEwoLbWF4X3N0YW1pbmEYCCABKAUSHwoEdHlwZRgJIAEoDjIR",
-                    "LkFsbEVudW0uRm9ydFR5cGUSEAoIbGF0aXR1ZGUYCiABKAESEQoJbG9uZ2l0",
-                    "dWRlGAsgASgBEhMKC2Rlc2NyaXB0aW9uGAwgASgJEkIKCW1vZGlmaWVycxgN",
-                    "IAMoCzIvLlBva2Vtb25Hby5Sb2NrZXRBUEkuR2VuZXJhdGVkQ29kZS5Gb3J0",
-                    "TW9kaWZpZXIicwoMRm9ydE1vZGlmaWVyEiAKB2l0ZW1faWQYASABKA4yDy5B",
-                    "bGxFbnVtLkl0ZW1JZBIfChdleHBpcmF0aW9uX3RpbWVzdGFtcF9tcxgCIAEo",
-                    "AxIgChhkZXBsb3llcl9wbGF5ZXJfY29kZW5hbWUYAyABKAkicgoQRW5jb3Vu",
-                    "dGVyUmVxdWVzdBIUCgxlbmNvdW50ZXJfaWQYASABKAYSFQoNc3Bhd25wb2lu",
-                    "dF9pZBgCIAEoCRIXCg9wbGF5ZXJfbGF0aXR1ZGUYAyABKAESGAoQcGxheWVy",
-                    "X2xvbmdpdHVkZRgEIAEoASLNBAoRRW5jb3VudGVyUmVzcG9uc2USRAoMd2ls",
-                    "ZF9wb2tlbW9uGAEgASgLMi4uUG9rZW1vbkdvLlJvY2tldEFQSS5HZW5lcmF0",
-                    "ZWRDb2RlLldpbGRQb2tlbW9uElMKCmJhY2tncm91bmQYAiABKA4yPy5Qb2tl",
-                    "bW9uR28uUm9ja2V0QVBJLkdlbmVyYXRlZENvZGUuRW5jb3VudGVyUmVzcG9u",
-                    "c2UuQmFja2dyb3VuZBJLCgZzdGF0dXMYAyABKA4yOy5Qb2tlbW9uR28uUm9j",
-                    "a2V0QVBJLkdlbmVyYXRlZENvZGUuRW5jb3VudGVyUmVzcG9uc2UuU3RhdHVz",
-                    "ElIKE2NhcHR1cmVfcHJvYmFiaWxpdHkYBCABKAsyNS5Qb2tlbW9uR28uUm9j",
-                    "a2V0QVBJLkdlbmVyYXRlZENvZGUuQ2FwdHVyZVByb2JhYmlsaXR5IiIKCkJh",
-                    "Y2tncm91bmQSCAoEUEFSSxAAEgoKBkRFU0VSVBABItcBCgZTdGF0dXMSEwoP",
-                    "RU5DT1VOVEVSX0VSUk9SEAASFQoRRU5DT1VOVEVSX1NVQ0NFU1MQARIXChNF",
-                    "TkNPVU5URVJfTk9UX0ZPVU5EEAISFAoQRU5DT1VOVEVSX0NMT1NFRBADEhoK",
-                    "FkVOQ09VTlRFUl9QT0tFTU9OX0ZMRUQQBBIaChZFTkNPVU5URVJfTk9UX0lO",
-                    "X1JBTkdFEAUSHgoaRU5DT1VOVEVSX0FMUkVBRFlfSEFQUEVORUQQBhIaChZQ",
-                    "T0tFTU9OX0lOVkVOVE9SWV9GVUxMEAciewoSQ2FwdHVyZVByb2JhYmlsaXR5",
-                    "EiYKDXBva2ViYWxsX3R5cGUYASADKA4yDy5BbGxFbnVtLkl0ZW1JZBIbChNj",
-                    "YXB0dXJlX3Byb2JhYmlsaXR5GAIgAygCEiAKGHJldGljbGVfZGlmZmljdWx0",
-                    "eV9zY2FsZRgMIAEoASJwChREaXNrRW5jb3VudGVyUmVxdWVzdBIUCgxlbmNv",
-                    "dW50ZXJfaWQYASABKAYSDwoHZm9ydF9pZBgCIAEoCRIXCg9wbGF5ZXJfbGF0",
-                    "aXR1ZGUYAyABKAESGAoQcGxheWVyX2xvbmdpdHVkZRgEIAEoASKIAwoVRGlz",
-                    "a0VuY291bnRlclJlc3BvbnNlEk8KBnJlc3VsdBgBIAEoDjI/LlBva2Vtb25H",
-                    "by5Sb2NrZXRBUEkuR2VuZXJhdGVkQ29kZS5EaXNrRW5jb3VudGVyUmVzcG9u",
-                    "c2UuUmVzdWx0EkQKDHBva2Vtb25fZGF0YRgCIAEoCzIuLlBva2Vtb25Hby5S",
-                    "b2NrZXRBUEkuR2VuZXJhdGVkQ29kZS5Qb2tlbW9uRGF0YRJSChNjYXB0dXJl",
-                    "X3Byb2JhYmlsaXR5GAMgASgLMjUuUG9rZW1vbkdvLlJvY2tldEFQSS5HZW5l",
-                    "cmF0ZWRDb2RlLkNhcHR1cmVQcm9iYWJpbGl0eSKDAQoGUmVzdWx0EgsKB1VO",
-                    "S05PV04QABILCgdTVUNDRVNTEAESEQoNTk9UX0FWQUlMQUJMRRACEhAKDE5P",
-                    "VF9JTl9SQU5HRRADEh4KGkVOQ09VTlRFUl9BTFJFQURZX0ZJTklTSEVEEAQS",
-                    "GgoWUE9LRU1PTl9JTlZFTlRPUllfRlVMTBAFIsMBChNDYXRjaFBva2Vtb25S",
-                    "ZXF1ZXN0EhQKDGVuY291bnRlcl9pZBgBIAEoBhIQCghwb2tlYmFsbBgCIAEo",
-                    "BRIfChdub3JtYWxpemVkX3JldGljbGVfc2l6ZRgDIAEoARIYChBzcGF3bl9w",
-                    "b2ludF9ndWlkGAQgASgJEhMKC2hpdF9wb2tlbW9uGAUgASgIEhUKDXNwaW5f",
-                    "bW9kaWZpZXIYBiABKAESHQoVTm9ybWFsaXplZEhpdFBvc2l0aW9uGAcgASgB",
-                    "IsYCChRDYXRjaFBva2Vtb25SZXNwb25zZRJTCgZzdGF0dXMYASABKA4yQy5Q",
-                    "b2tlbW9uR28uUm9ja2V0QVBJLkdlbmVyYXRlZENvZGUuQ2F0Y2hQb2tlbW9u",
-                    "UmVzcG9uc2UuQ2F0Y2hTdGF0dXMSFAoMbWlzc19wZXJjZW50GAIgASgBEhsK",
-                    "E2NhcHR1cmVkX3Bva2Vtb25faWQYAyABKAQSPwoGc2NvcmVzGAQgASgLMi8u",
-                    "UG9rZW1vbkdvLlJvY2tldEFQSS5HZW5lcmF0ZWRDb2RlLkNhcHR1cmVTY29y",
-                    "ZSJlCgtDYXRjaFN0YXR1cxIPCgtDQVRDSF9FUlJPUhAAEhEKDUNBVENIX1NV",
-                    "Q0NFU1MQARIQCgxDQVRDSF9FU0NBUEUQAhIOCgpDQVRDSF9GTEVFEAMSEAoM",
-                    "Q0FUQ0hfTUlTU0VEEAQiaQoMQ2FwdHVyZVNjb3JlEiwKDWFjdGl2aXR5X3R5",
-                    "cGUYASADKA4yFS5BbGxFbnVtLkFjdGl2aXR5VHlwZRIKCgJ4cBgCIAMoBRIN",
-                    "CgVjYW5keRgDIAMoBRIQCghzdGFyZHVzdBgEIAMoBSIbChlDaGVja0F3YXJk",
-                    "ZWRCYWRnZXNSZXF1ZXN0IncKGkNoZWNrQXdhcmRlZEJhZGdlc1Jlc3BvbnNl",
-                    "Eg8KB3N1Y2Nlc3MYASABKAgSKgoOYXdhcmRlZF9iYWRnZXMYAiADKA4yEi5B",
-                    "bGxFbnVtLkJhZGdlVHlwZRIcChRhd2FyZGVkX2JhZGdlX2xldmVscxgDIAMo",
-                    "BSJ5ChVFcXVpcHBlZEJhZGdlU2V0dGluZ3MSHwoXZXF1aXBfYmFkZ2VfY29v",
-                    "bGRvd25fbXMYASABKAMSHwoXY2F0Y2hfcHJvYmFiaWxpdHlfYm9udXMYAiAD",
-                    "KAISHgoWZmxlZV9wcm9iYWJpbGl0eV9ib251cxgDIAMoAiKEAQoWUG9rZW1v",
-                    "blVwZ3JhZGVTZXR0aW5ncxIaChJ1cGdyYWRlc19wZXJfbGV2ZWwYASABKAUS",
-                    "IwobYWxsb3dlZF9sZXZlbHNfYWJvdmVfcGxheWVyGAIgASgFEhIKCmNhbmR5",
-                    "X2Nvc3QYAyADKAUSFQoNc3RhcmR1c3RfY29zdBgEIAMoBSKMAgoLSWFwU2V0",
-                    "dGluZ3MSGQoRZGFpbHlfYm9udXNfY29pbnMYASABKAUSKAogZGFpbHlfZGVm",
-                    "ZW5kZXJfYm9udXNfcGVyX3Bva2Vtb24YAiADKAUSKgoiZGFpbHlfZGVmZW5k",
-                    "ZXJfYm9udXNfbWF4X2RlZmVuZGVycxgDIAEoBRIlCh1kYWlseV9kZWZlbmRl",
-                    "cl9ib251c19jdXJyZW5jeRgEIAMoCRIiChptaW5fdGltZV9iZXR3ZWVuX2Ns",
-                    "YWltc19tcxgFIAEoAxIbChNkYWlseV9ib251c19lbmFibGVkGAYgASgIEiQK",
-                    "HGRhaWx5X2RlZmVuZGVyX2JvbnVzX2VuYWJsZWQYByABKAgilAEKDklhcEl0",
-                    "ZW1EaXNwbGF5EgsKA3NrdRgBIAEoCRIuCghjYXRlZ29yeRgCIAEoDjIcLkFs",
-                    "bEVudW0uSG9sb0lhcEl0ZW1DYXRlZ29yeRISCgpzb3J0X29yZGVyGAMgASgF",
-                    "EiEKCGl0ZW1faWRzGAQgAygOMg8uQWxsRW51bS5JdGVtSWQSDgoGY291bnRz",
-                    "GAUgAygFIq4BChFFbmNvdW50ZXJTZXR0aW5ncxIcChRzcGluX2JvbnVzX3Ro",
-                    "cmVzaG9sZBgBIAEoAhIhChlleGNlbGxlbnRfdGhyb3dfdGhyZXNob2xkGAIg",
-                    "ASgCEh0KFWdyZWF0X3Rocm93X3RocmVzaG9sZBgDIAEoAhIcChRuaWNlX3Ro",
-                    "cm93X3RocmVzaG9sZBgEIAEoAhIbChNtaWxlc3RvbmVfdGhyZXNob2xkGAUg",
-                    "ASgFIsYDChFHeW1CYXR0bGVTZXR0aW5ncxIWCg5lbmVyZ3lfcGVyX3NlYxgB",
-                    "IAEoAhIZChFkb2RnZV9lbmVyZ3lfY29zdBgCIAEoAhIYChByZXRhcmdldF9z",
-                    "ZWNvbmRzGAMgASgCEh0KFWVuZW15X2F0dGFja19pbnRlcnZhbBgEIAEoAhIe",
-                    "ChZhdHRhY2tfc2VydmVyX2ludGVydmFsGAUgASgCEh4KFnJvdW5kX2R1cmF0",
-                    "aW9uX3NlY29uZHMYBiABKAISIwobYm9udXNfdGltZV9wZXJfYWxseV9zZWNv",
-                    "bmRzGAcgASgCEiQKHG1heGltdW1fYXR0YWNrZXJzX3Blcl9iYXR0bGUYCCAB",
-                    "KAUSKQohc2FtZV90eXBlX2F0dGFja19ib251c19tdWx0aXBsaWVyGAkgASgC",
-                    "EhYKDm1heGltdW1fZW5lcmd5GAogASgFEiQKHGVuZXJneV9kZWx0YV9wZXJf",
-                    "aGVhbHRoX2xvc3QYCyABKAISGQoRZG9kZ2VfZHVyYXRpb25fbXMYDCABKAUS",
-                    "HAoUbWluaW11bV9wbGF5ZXJfbGV2ZWwYDSABKAUSGAoQc3dhcF9kdXJhdGlv",
-                    "bl9tcxgOIAEoBSJ3ChBHeW1MZXZlbFNldHRpbmdzEhsKE3JlcXVpcmVkX2V4",
-                    "cGVyaWVuY2UYASADKAUSFAoMbGVhZGVyX3Nsb3RzGAIgAygFEhUKDXRyYWlu",
-                    "ZXJfc2xvdHMYAyADKAUSGQoRc2VhcmNoX3JvbGxfYm9udXMYBCADKAUinQEK",
-                    "E1BsYXllckxldmVsU2V0dGluZ3MSEAoIcmFua19udW0YASADKAUSGwoTcmVx",
-                    "dWlyZWRfZXhwZXJpZW5jZRgCIAMoBRIVCg1jcF9tdWx0aXBsaWVyGAMgAygC",
-                    "EhwKFG1heF9lZ2dfcGxheWVyX2xldmVsGAQgASgFEiIKGm1heF9lbmNvdW50",
-                    "ZXJfcGxheWVyX2xldmVsGAUgASgFIsUDCg5DYW1lcmFTZXR0aW5ncxITCgtu",
-                    "ZXh0X2NhbWVyYRgBIAEoCRIzCg1pbnRlcnBvbGF0aW9uGAIgAygOMhwuQWxs",
-                    "RW51bS5DYW1lcmFJbnRlcnBvbGF0aW9uEioKC3RhcmdldF90eXBlGAMgAygO",
-                    "MhUuQWxsRW51bS5DYW1lcmFUYXJnZXQSFQoNZWFzZV9pbl9zcGVlZBgEIAMo",
-                    "AhIWCg5lYXN0X291dF9zcGVlZBgFIAMoAhIYChBkdXJhdGlvbl9zZWNvbmRz",
-                    "GAYgAygCEhQKDHdhaXRfc2Vjb25kcxgHIAMoAhIaChJ0cmFuc2l0aW9uX3Nl",
-                    "Y29uZHMYCCADKAISFAoMYW5nbGVfZGVncmVlGAkgAygCEhsKE2FuZ2xlX29m",
-                    "ZnNldF9kZWdyZWUYCiADKAISFAoMcGl0Y2hfZGVncmVlGAsgAygCEhsKE3Bp",
-                    "dGNoX29mZnNldF9kZWdyZWUYDCADKAISEwoLcm9sbF9kZWdyZWUYDSADKAIS",
-                    "FwoPZGlzdGFuY2VfbWV0ZXJzGA4gAygCEhYKDmhlaWdodF9wZXJjZW50GA8g",
-                    "AygCEhYKDnZlcnRfY3RyX3JhdGlvGBAgAygCIlwKDUJhZGdlU2V0dGluZ3MS",
-                    "JgoKYmFkZ2VfdHlwZRgBIAEoDjISLkFsbEVudW0uQmFkZ2VUeXBlEhIKCmJh",
-                    "ZGdlX3JhbmsYAiABKAUSDwoHdGFyZ2V0cxgDIAMoBSJZChVUeXBlRWZmZWN0",
-                    "aXZlU2V0dGluZ3MSFQoNYXR0YWNrX3NjYWxhchgBIAMoAhIpCgthdHRhY2tf",
-                    "dHlwZRgCIAEoDjIULkFsbEVudW0uUG9rZW1vblR5cGUiKAoUTW92ZVNlcXVl",
-                    "bmNlU2V0dGluZ3MSEAoIc2VxdWVuY2UYASADKAkipwMKDE1vdmVTZXR0aW5n",
-                    "cxIxCgttb3ZlbWVudF9pZBgBIAEoDjIcLkFsbEVudW0uUG9rZW1vbk1vdmVt",
-                    "ZW50VHlwZRIUCgxhbmltYXRpb25faWQYAiABKAUSKgoMcG9rZW1vbl90eXBl",
-                    "GAMgASgOMhQuQWxsRW51bS5Qb2tlbW9uVHlwZRINCgVwb3dlchgEIAEoAhIX",
-                    "Cg9hY2N1cmFjeV9jaGFuY2UYBSABKAISFwoPY3JpdGljYWxfY2hhbmNlGAYg",
-                    "ASgCEhMKC2hlYWxfc2NhbGFyGAcgASgCEhsKE3N0YW1pbmFfbG9zc19zY2Fs",
-                    "YXIYCCABKAISGQoRdHJhaW5lcl9sZXZlbF9taW4YCSABKAUSGQoRdHJhaW5l",
-                    "cl9sZXZlbF9tYXgYCiABKAUSEAoIdmZ4X25hbWUYCyABKAkSEwoLZHVyYXRp",
-                    "b25fbXMYDCABKAUSHgoWZGFtYWdlX3dpbmRvd19zdGFydF9tcxgNIAEoBRIc",
-                    "ChRkYW1hZ2Vfd2luZG93X2VuZF9tcxgOIAEoBRIUCgxlbmVyZ3lfZGVsdGEY",
-                    "DyABKAUivgYKD1Bva2Vtb25TZXR0aW5ncxImCgpwb2tlbW9uX2lkGAEgASgO",
-                    "MhIuQWxsRW51bS5Qb2tlbW9uSWQSEwoLbW9kZWxfc2NhbGUYAyABKAISIgoE",
-                    "dHlwZRgEIAEoDjIULkFsbEVudW0uUG9rZW1vblR5cGUSJAoGdHlwZV8yGAUg",
-                    "ASgOMhQuQWxsRW51bS5Qb2tlbW9uVHlwZRJDCgZjYW1lcmEYBiABKAsyMy5Q",
-                    "b2tlbW9uR28uUm9ja2V0QVBJLkdlbmVyYXRlZENvZGUuQ2FtZXJhQXR0cmli",
-                    "dXRlcxJJCgllbmNvdW50ZXIYByABKAsyNi5Qb2tlbW9uR28uUm9ja2V0QVBJ",
-                    "LkdlbmVyYXRlZENvZGUuRW5jb3VudGVyQXR0cmlidXRlcxJBCgVzdGF0cxgI",
-                    "IAEoCzIyLlBva2Vtb25Hby5Sb2NrZXRBUEkuR2VuZXJhdGVkQ29kZS5TdGF0",
-                    "c0F0dHJpYnV0ZXMSKQoLcXVpY2tfbW92ZXMYCSADKA4yFC5BbGxFbnVtLlBv",
-                    "a2Vtb25Nb3ZlEi0KD2NpbmVtYXRpY19tb3ZlcxgKIAMoDjIULkFsbEVudW0u",
-                    "UG9rZW1vbk1vdmUSFgoOYW5pbWF0aW9uX3RpbWUYCyADKAISKQoNZXZvbHV0",
-                    "aW9uX2lkcxgMIAMoDjISLkFsbEVudW0uUG9rZW1vbklkEhYKDmV2b2x1dGlv",
-                    "bl9waXBzGA0gASgFEiQKBWNsYXNzGA4gASgOMhUuQWxsRW51bS5Qb2tlbW9u",
-                    "Q2xhc3MSGAoQcG9rZWRleF9oZWlnaHRfbRgPIAEoAhIZChFwb2tlZGV4X3dl",
-                    "aWdodF9rZxgQIAEoAhItChFwYXJlbnRfcG9rZW1vbl9pZBgRIAEoDjISLkFs",
-                    "bEVudW0uUG9rZW1vbklkEhYKDmhlaWdodF9zdGRfZGV2GBIgASgCEhYKDndl",
-                    "aWdodF9zdGRfZGV2GBMgASgCEhwKFGttX2Rpc3RhbmNlX3RvX2hhdGNoGBQg",
-                    "ASgCEisKCWZhbWlseV9pZBgVIAEoDjIYLkFsbEVudW0uUG9rZW1vbkZhbWls",
-                    "eUlkEhcKD2NhbmR5X3RvX2V2b2x2ZRgWIAEoBSKXAQoQQ2FtZXJhQXR0cmli",
-                    "dXRlcxIVCg1kaXNrX3JhZGl1c19tGAEgASgCEhkKEWN5bGluZGVyX3JhZGl1",
-                    "c19tGAIgASgCEhkKEWN5bGluZGVyX2hlaWdodF9tGAMgASgCEhkKEWN5bGlu",
-                    "ZGVyX2dyb3VuZF9tGAQgASgCEhsKE3Nob3VsZGVyX21vZGVfc2NhbGUYBSAB",
-                    "KAIinQIKE0VuY291bnRlckF0dHJpYnV0ZXMSGQoRYmFzZV9jYXB0dXJlX3Jh",
-                    "dGUYASABKAISFgoOYmFzZV9mbGVlX3JhdGUYAiABKAISGgoSY29sbGlzaW9u",
-                    "X3JhZGl1c19tGAMgASgCEhoKEmNvbGxpc2lvbl9oZWlnaHRfbRgEIAEoAhIf",
-                    "Chdjb2xsaXNpb25faGVhZF9yYWRpdXNfbRgFIAEoAhIzCg1tb3ZlbWVudF90",
-                    "eXBlGAYgASgOMhwuQWxsRW51bS5Qb2tlbW9uTW92ZW1lbnRUeXBlEhgKEG1v",
-                    "dmVtZW50X3RpbWVyX3MYByABKAISEwoLanVtcF90aW1lX3MYCCABKAISFgoO",
-                    "YXR0YWNrX3RpbWVyX3MYCSABKAIibgoPU3RhdHNBdHRyaWJ1dGVzEhQKDGJh",
-                    "c2Vfc3RhbWluYRgBIAEoBRITCgtiYXNlX2F0dGFjaxgCIAEoBRIUCgxiYXNl",
-                    "X2RlZmVuc2UYAyABKAUSGgoSZG9kZ2VfZW5lcmd5X2RlbHRhGAggASgFIpwH",
-                    "CgxJdGVtU2V0dGluZ3MSIAoHaXRlbV9pZBgBIAEoDjIPLkFsbEVudW0uSXRl",
-                    "bUlkEiQKCWl0ZW1fdHlwZRgCIAEoDjIRLkFsbEVudW0uSXRlbVR5cGUSJwoI",
-                    "Y2F0ZWdvcnkYAyABKA4yFS5BbGxFbnVtLkl0ZW1DYXRlZ29yeRIRCglkcm9w",
-                    "X2ZyZXEYBCABKAISGgoSZHJvcF90cmFpbmVyX2xldmVsGAUgASgFEkcKCHBv",
-                    "a2ViYWxsGAYgASgLMjUuUG9rZW1vbkdvLlJvY2tldEFQSS5HZW5lcmF0ZWRD",
-                    "b2RlLlBva2ViYWxsQXR0cmlidXRlcxJDCgZwb3Rpb24YByABKAsyMy5Qb2tl",
-                    "bW9uR28uUm9ja2V0QVBJLkdlbmVyYXRlZENvZGUuUG90aW9uQXR0cmlidXRl",
-                    "cxJDCgZyZXZpdmUYCCABKAsyMy5Qb2tlbW9uR28uUm9ja2V0QVBJLkdlbmVy",
-                    "YXRlZENvZGUuUmV2aXZlQXR0cmlidXRlcxJDCgZiYXR0bGUYCSABKAsyMy5Q",
-                    "b2tlbW9uR28uUm9ja2V0QVBJLkdlbmVyYXRlZENvZGUuQmF0dGxlQXR0cmli",
-                    "dXRlcxI/CgRmb29kGAogASgLMjEuUG9rZW1vbkdvLlJvY2tldEFQSS5HZW5l",
-                    "cmF0ZWRDb2RlLkZvb2RBdHRyaWJ1dGVzElgKEWludmVudG9yeV91cGdyYWRl",
-                    "GAsgASgLMj0uUG9rZW1vbkdvLlJvY2tldEFQSS5HZW5lcmF0ZWRDb2RlLklu",
-                    "dmVudG9yeVVwZ3JhZGVBdHRyaWJ1dGVzEk4KCHhwX2Jvb3N0GAwgASgLMjwu",
-                    "UG9rZW1vbkdvLlJvY2tldEFQSS5HZW5lcmF0ZWRDb2RlLkV4cGVyaWVuY2VC",
-                    "b29zdEF0dHJpYnV0ZXMSRQoHaW5jZW5zZRgNIAEoCzI0LlBva2Vtb25Hby5S",
-                    "b2NrZXRBUEkuR2VuZXJhdGVkQ29kZS5JbmNlbnNlQXR0cmlidXRlcxJQCg1l",
-                    "Z2dfaW5jdWJhdG9yGA4gASgLMjkuUG9rZW1vbkdvLlJvY2tldEFQSS5HZW5l",
-                    "cmF0ZWRDb2RlLkVnZ0luY3ViYXRvckF0dHJpYnV0ZXMSUAoNZm9ydF9tb2Rp",
-                    "ZmllchgPIAEoCzI5LlBva2Vtb25Hby5Sb2NrZXRBUEkuR2VuZXJhdGVkQ29k",
-                    "ZS5Gb3J0TW9kaWZpZXJBdHRyaWJ1dGVzIicKEEJhdHRsZUF0dHJpYnV0ZXMS",
-                    "EwoLc3RhX3BlcmNlbnQYASABKAIidgoWRWdnSW5jdWJhdG9yQXR0cmlidXRl",
-                    "cxIxCg5pbmN1YmF0b3JfdHlwZRgBIAEoDjIZLkFsbEVudW0uRWdnSW5jdWJh",
-                    "dG9yVHlwZRIMCgR1c2VzGAIgASgFEhsKE2Rpc3RhbmNlX211bHRpcGxpZXIY",
-                    "AyABKAIiTQoZRXhwZXJpZW5jZUJvb3N0QXR0cmlidXRlcxIVCg14cF9tdWx0",
-                    "aXBsaWVyGAEgASgCEhkKEWJvb3N0X2R1cmF0aW9uX21zGAIgASgFIm8KDkZv",
-                    "b2RBdHRyaWJ1dGVzEigKC2l0ZW1fZWZmZWN0GAEgAygOMhMuQWxsRW51bS5J",
-                    "dGVtRWZmZWN0EhsKE2l0ZW1fZWZmZWN0X3BlcmNlbnQYAiADKAISFgoOZ3Jv",
-                    "d3RoX3BlcmNlbnQYAyABKAIiYgoWRm9ydE1vZGlmaWVyQXR0cmlidXRlcxIh",
-                    "Chltb2RpZmllcl9saWZldGltZV9zZWNvbmRzGAEgASgFEiUKHXRyb3lfZGlz",
-                    "a19udW1fcG9rZW1vbl9zcGF3bmVkGAIgASgFIskCChFJbmNlbnNlQXR0cmli",
-                    "dXRlcxIgChhpbmNlbnNlX2xpZmV0aW1lX3NlY29uZHMYASABKAUSKgoMcG9r",
-                    "ZW1vbl90eXBlGAIgAygOMhQuQWxsRW51bS5Qb2tlbW9uVHlwZRIoCiBwb2tl",
-                    "bW9uX2luY2Vuc2VfdHlwZV9wcm9iYWJpbGl0eRgDIAEoAhIwCihzdGFuZGlu",
-                    "Z190aW1lX2JldHdlZW5fZW5jb3VudGVyc19zZWNvbmRzGAQgASgFEi0KJW1v",
-                    "dmluZ190aW1lX2JldHdlZW5fZW5jb3VudGVyX3NlY29uZHMYBSABKAUSNQot",
-                    "ZGlzdGFuY2VfcmVxdWlyZWRfZm9yX3Nob3J0ZXJfaW50ZXJ2YWxfbWV0ZXJz",
-                    "GAYgASgFEiQKHHBva2Vtb25fYXR0cmFjdGVkX2xlbmd0aF9zZWMYByABKAUi",
-                    "bQoaSW52ZW50b3J5VXBncmFkZUF0dHJpYnV0ZXMSGgoSYWRkaXRpb25hbF9z",
-                    "dG9yYWdlGAEgASgFEjMKDHVwZ3JhZGVfdHlwZRgCIAEoDjIdLkFsbEVudW0u",
-                    "SW52ZW50b3J5VXBncmFkZVR5cGUijAEKElBva2ViYWxsQXR0cmlidXRlcxIo",
-                    "CgtpdGVtX2VmZmVjdBgBIAEoDjITLkFsbEVudW0uSXRlbUVmZmVjdBIVCg1j",
-                    "YXB0dXJlX211bHRpGAIgASgCEhwKFGNhcHR1cmVfbXVsdGlfZWZmZWN0GAMg",
-                    "ASgCEhcKD2l0ZW1fZWZmZWN0X21vZBgEIAEoAiI7ChBQb3Rpb25BdHRyaWJ1",
-                    "dGVzEhMKC3N0YV9wZXJjZW50GAEgASgCEhIKCnN0YV9hbW91bnQYAiABKAUi",
-                    "JwoQUmV2aXZlQXR0cmlidXRlcxITCgtzdGFfcGVyY2VudBgBIAEoAiIkCg9U",
-                    "cmFuc2ZlclBva2Vtb24SEQoJUG9rZW1vbklkGAEgASgGIjoKElRyYW5zZmVy",
-                    "UG9rZW1vbk91dBIOCgZTdGF0dXMYASABKAUSFAoMQ2FuZHlBd2FyZGVkGAIg",
-                    "ASgFIiIKDUV2b2x2ZVBva2Vtb24SEQoJUG9rZW1vbklkGAEgASgGIqoDChBF",
-                    "dm9sdmVQb2tlbW9uT3V0ElcKBlJlc3VsdBgBIAEoDjJHLlBva2Vtb25Hby5S",
-                    "b2NrZXRBUEkuR2VuZXJhdGVkQ29kZS5Fdm9sdmVQb2tlbW9uT3V0LkV2b2x2",
-                    "ZVBva2Vtb25TdGF0dXMSQgoORXZvbHZlZFBva2Vtb24YAiABKAsyKi5Qb2tl",
-                    "bW9uR28uUm9ja2V0QVBJLkdlbmVyYXRlZENvZGUuUG9rZW1vbhISCgpFeHBB",
-                    "d2FyZGVkGAMgASgFEhQKDENhbmR5QXdhcmRlZBgEIAEoBSLOAQoTRXZvbHZl",
-                    "UG9rZW1vblN0YXR1cxIZChVQT0tFTU9OX0VWT0xWRURfVU5TRVQQABIbChdQ",
-                    "T0tFTU9OX0VWT0xWRURfU1VDQ0VTUxABEhoKFkZBSUxFRF9QT0tFTU9OX01J",
-                    "U1NJTkcQAhIhCh1GQUlMRURfSU5TVUZGSUNJRU5UX1JFU09VUkNFUxADEiAK",
-                    "HEZBSUxFRF9QT0tFTU9OX0NBTk5PVF9FVk9MVkUQBBIeChpGQUlMRURfUE9L",
-                    "RU1PTl9JU19ERVBMT1lFRBAFYgZwcm90bzM="));
-            descriptor = pbr::FileDescriptor.FromGeneratedCode(descriptorData,
-                new pbr::FileDescriptor[] { global::PokemonGo.RocketAPI.GeneratedCode.AllEnumReflection.Descriptor, },
-                new pbr::GeneratedClrTypeInfo(null, new pbr::GeneratedClrTypeInfo[]
-                {
-                    new pbr::GeneratedClrTypeInfo(typeof(global::PokemonGo.RocketAPI.GeneratedCode.GetPlayerResponse),
-                        global::PokemonGo.RocketAPI.GeneratedCode.GetPlayerResponse.Parser,
-                        new[] {"Unknown1", "Profile"}, null, null, null),
-                    new pbr::GeneratedClrTypeInfo(typeof(global::PokemonGo.RocketAPI.GeneratedCode.Profile),
-                        global::PokemonGo.RocketAPI.GeneratedCode.Profile.Parser,
-                        new[]
-                        {
-                            "CreationTime", "Username", "Team", "Tutorial", "Avatar", "PokeStorage", "ItemStorage",
-                            "DailyBonus", "Unknown12", "Unknown13", "Currency"
-                        }, null, null, null),
-                    new pbr::GeneratedClrTypeInfo(typeof(global::PokemonGo.RocketAPI.GeneratedCode.DailyBonus),
-                        global::PokemonGo.RocketAPI.GeneratedCode.DailyBonus.Parser,
-                        new[] {"NextCollectTimestampMs", "NextDefenderBonusCollectTimestampMs"}, null, null, null),
-                    new pbr::GeneratedClrTypeInfo(typeof(global::PokemonGo.RocketAPI.GeneratedCode.Currency),
-                        global::PokemonGo.RocketAPI.GeneratedCode.Currency.Parser, new[] {"Type", "Amount"}, null, null,
-                        null),
-                    new pbr::GeneratedClrTypeInfo(typeof(global::PokemonGo.RocketAPI.GeneratedCode.AvatarDetails),
-                        global::PokemonGo.RocketAPI.GeneratedCode.AvatarDetails.Parser,
-                        new[] {"Unknown2", "Unknown3", "Unknown9", "Unknown10"}, null, null, null),
-                    new pbr::GeneratedClrTypeInfo(
-                        typeof(global::PokemonGo.RocketAPI.GeneratedCode.DownloadSettingsRequest),
-                        global::PokemonGo.RocketAPI.GeneratedCode.DownloadSettingsRequest.Parser, new[] {"Hash"}, null,
-                        null, null),
-                    new pbr::GeneratedClrTypeInfo(
-                        typeof(global::PokemonGo.RocketAPI.GeneratedCode.GetInventoryResponse),
-                        global::PokemonGo.RocketAPI.GeneratedCode.GetInventoryResponse.Parser,
-                        new[] {"Success", "InventoryDelta"}, null, null, null),
-                    new pbr::GeneratedClrTypeInfo(typeof(global::PokemonGo.RocketAPI.GeneratedCode.InventoryDelta),
-                        global::PokemonGo.RocketAPI.GeneratedCode.InventoryDelta.Parser,
-                        new[] {"OriginalTimestampMs", "NewTimestampMs", "InventoryItems"}, null, null, null),
-                    new pbr::GeneratedClrTypeInfo(typeof(global::PokemonGo.RocketAPI.GeneratedCode.InventoryItem),
-                        global::PokemonGo.RocketAPI.GeneratedCode.InventoryItem.Parser,
-                        new[] {"ModifiedTimestampMs", "DeletedItemKey", "InventoryItemData"}, null, null, null),
-                    new pbr::GeneratedClrTypeInfo(typeof(global::PokemonGo.RocketAPI.GeneratedCode.InventoryItemData),
-                        global::PokemonGo.RocketAPI.GeneratedCode.InventoryItemData.Parser,
-                        new[]
-                        {
-                            "Pokemon", "Item", "PokedexEntry", "PlayerStats", "PlayerCurrency", "PlayerCamera",
-                            "InventoryUpgrades", "AppliedItems", "EggIncubators", "PokemonFamily"
-                        }, null, null, null),
-                    new pbr::GeneratedClrTypeInfo(
-                        typeof(global::PokemonGo.RocketAPI.GeneratedCode.RecycleInventoryItem),
-                        global::PokemonGo.RocketAPI.GeneratedCode.RecycleInventoryItem.Parser, new[] {"ItemId", "Count"},
-                        null, null, null),
-                    new pbr::GeneratedClrTypeInfo(typeof(global::PokemonGo.RocketAPI.GeneratedCode.Pokemon),
-                        global::PokemonGo.RocketAPI.GeneratedCode.Pokemon.Parser,
-                        new[]
-                        {
-                            "Id", "PokemonType", "Cp", "Stamina", "StaminaMax", "Move1", "Move2", "DeployedFortId",
-                            "OwnerName", "IsEgg", "EggKmWalkedTarget", "EggKmWalkedStart", "Origin", "HeightM",
-                            "WeightKg", "IndividualAttack", "IndividualDefense", "IndividualStamina", "CpMultiplier",
-                            "Pokeball", "CapturedCellId", "BattlesAttacked", "BattlesDefended", "EggIncubatorId",
-                            "CreationTimeMs", "NumUpgrades", "AdditionalCpMultiplier", "Favorite", "Nickname",
-                            "FromFort"
-                        }, null, null, null),
-                    new pbr::GeneratedClrTypeInfo(typeof(global::PokemonGo.RocketAPI.GeneratedCode.Item),
-                        global::PokemonGo.RocketAPI.GeneratedCode.Item.Parser, new[] {"Item_", "Count", "Unseen"}, null,
-                        null, null),
-                    new pbr::GeneratedClrTypeInfo(typeof(global::PokemonGo.RocketAPI.GeneratedCode.PokedexEntry),
-                        global::PokemonGo.RocketAPI.GeneratedCode.PokedexEntry.Parser,
-                        new[]
-                        {
-                            "PokedexEntryNumber", "TimesEncountered", "TimesCaptured", "EvolutionStonePieces",
-                            "EvolutionStones"
-                        }, null, null, null),
-                    new pbr::GeneratedClrTypeInfo(typeof(global::PokemonGo.RocketAPI.GeneratedCode.PlayerStats),
-                        global::PokemonGo.RocketAPI.GeneratedCode.PlayerStats.Parser,
-                        new[]
-                        {
-                            "Level", "Experience", "PrevLevelXp", "NextLevelXp", "KmWalked", "PokemonsEncountered",
-                            "UniquePokedexEntries", "PokemonsCaptured", "Evolutions", "PokeStopVisits",
-                            "PokeballsThrown", "EggsHatched", "BigMagikarpCaught", "BattleAttackWon",
-                            "BattleAttackTotal", "BattleDefendedWon", "BattleTrainingWon", "BattleTrainingTotal",
-                            "PrestigeRaisedTotal", "PrestigeDroppedTotal", "PokemonDeployed", "PokemonCaughtByType",
-                            "SmallRattataCaught"
-                        }, null, null, null),
-                    new pbr::GeneratedClrTypeInfo(typeof(global::PokemonGo.RocketAPI.GeneratedCode.PlayerCurrency),
-                        global::PokemonGo.RocketAPI.GeneratedCode.PlayerCurrency.Parser, new[] {"Gems"}, null, null,
-                        null),
-                    new pbr::GeneratedClrTypeInfo(typeof(global::PokemonGo.RocketAPI.GeneratedCode.PlayerCamera),
-                        global::PokemonGo.RocketAPI.GeneratedCode.PlayerCamera.Parser, new[] {"IsDefaultCamera"}, null,
-                        null, null),
-                    new pbr::GeneratedClrTypeInfo(typeof(global::PokemonGo.RocketAPI.GeneratedCode.InventoryUpgrades),
-                        global::PokemonGo.RocketAPI.GeneratedCode.InventoryUpgrades.Parser, new[] {"InventoryUpgrades_"},
-                        null, null, null),
-                    new pbr::GeneratedClrTypeInfo(typeof(global::PokemonGo.RocketAPI.GeneratedCode.InventoryUpgrade),
-                        global::PokemonGo.RocketAPI.GeneratedCode.InventoryUpgrade.Parser,
-                        new[] {"Item", "UpgradeType", "AdditionalStorage"}, null, null, null),
-                    new pbr::GeneratedClrTypeInfo(typeof(global::PokemonGo.RocketAPI.GeneratedCode.AppliedItems),
-                        global::PokemonGo.RocketAPI.GeneratedCode.AppliedItems.Parser, new[] {"Item"}, null, null, null),
-                    new pbr::GeneratedClrTypeInfo(typeof(global::PokemonGo.RocketAPI.GeneratedCode.AppliedItem),
-                        global::PokemonGo.RocketAPI.GeneratedCode.AppliedItem.Parser,
-                        new[] {"ItemType", "ItemTypeCategory", "ExpireMs", "AppliedMs"}, null, null, null),
-                    new pbr::GeneratedClrTypeInfo(typeof(global::PokemonGo.RocketAPI.GeneratedCode.EggIncubators),
-                        global::PokemonGo.RocketAPI.GeneratedCode.EggIncubators.Parser, new[] {"EggIncubator"}, null,
-                        null, null),
-                    new pbr::GeneratedClrTypeInfo(typeof(global::PokemonGo.RocketAPI.GeneratedCode.EggIncubator),
-                        global::PokemonGo.RocketAPI.GeneratedCode.EggIncubator.Parser,
-                        new[]
-                        {
-                            "ItemId", "ItemType", "IncubatorType", "UsesRemaining", "PokemonId", "StartKmWalked",
-                            "TargetKmWalked"
-                        }, null, null, null),
-                    new pbr::GeneratedClrTypeInfo(typeof(global::PokemonGo.RocketAPI.GeneratedCode.PokemonFamily),
-                        global::PokemonGo.RocketAPI.GeneratedCode.PokemonFamily.Parser, new[] {"FamilyId", "Candy"},
-                        null, null, null),
-                    new pbr::GeneratedClrTypeInfo(
-                        typeof(global::PokemonGo.RocketAPI.GeneratedCode.GetMapObjectsRequest),
-                        global::PokemonGo.RocketAPI.GeneratedCode.GetMapObjectsRequest.Parser,
-                        new[] {"CellId", "SinceTimestampMs", "Latitude", "Longitude"}, null, null, null),
-                    new pbr::GeneratedClrTypeInfo(
-                        typeof(global::PokemonGo.RocketAPI.GeneratedCode.GetMapObjectsResponse),
-                        global::PokemonGo.RocketAPI.GeneratedCode.GetMapObjectsResponse.Parser,
-                        new[] {"MapCells", "Status"}, null, null, null),
-                    new pbr::GeneratedClrTypeInfo(typeof(global::PokemonGo.RocketAPI.GeneratedCode.MapCell),
-                        global::PokemonGo.RocketAPI.GeneratedCode.MapCell.Parser,
-                        new[]
-                        {
-                            "S2CellId", "CurrentTimestampMs", "Forts", "SpawnPoints", "DeletedObjects", "IsTruncatedList",
-                            "FortSummaries", "DecimatedSpawnPoints", "WildPokemons", "CatchablePokemons",
-                            "NearbyPokemons"
-                        }, null, null, null),
-                    new pbr::GeneratedClrTypeInfo(typeof(global::PokemonGo.RocketAPI.GeneratedCode.FortData),
-                        global::PokemonGo.RocketAPI.GeneratedCode.FortData.Parser,
-                        new[]
-                        {
-                            "Id", "LastModifiedTimestampMs", "Latitude", "Longitude", "Enabled", "Type", "OwnedByTeam",
-                            "GuardPokemonId", "GuardPokemonCp", "GymPoints", "IsInBattle", "CooldownCompleteTimestampMs",
-                            "Sponsor", "RenderingType", "ActiveFortModifier", "LureInfo"
-                        }, null, null, null),
-                    new pbr::GeneratedClrTypeInfo(typeof(global::PokemonGo.RocketAPI.GeneratedCode.FortLureInfo),
-                        global::PokemonGo.RocketAPI.GeneratedCode.FortLureInfo.Parser,
-                        new[] {"FortId", "Unknown2", "ActivePokemonId", "LureExpiresTimestampMs"}, null, null, null),
-                    new pbr::GeneratedClrTypeInfo(typeof(global::PokemonGo.RocketAPI.GeneratedCode.SpawnPoint),
-                        global::PokemonGo.RocketAPI.GeneratedCode.SpawnPoint.Parser, new[] {"Latitude", "Longitude"},
-                        null, null, null),
-                    new pbr::GeneratedClrTypeInfo(typeof(global::PokemonGo.RocketAPI.GeneratedCode.FortSummary),
-                        global::PokemonGo.RocketAPI.GeneratedCode.FortSummary.Parser,
-                        new[] {"FortSummaryId", "LastModifiedTimestampMs", "Latitude", "Longitude"}, null, null, null),
-                    new pbr::GeneratedClrTypeInfo(typeof(global::PokemonGo.RocketAPI.GeneratedCode.WildPokemon),
-                        global::PokemonGo.RocketAPI.GeneratedCode.WildPokemon.Parser,
-                        new[]
-                        {
-                            "EncounterId", "LastModifiedTimestampMs", "Latitude", "Longitude", "SpawnpointId",
-                            "PokemonData", "TimeTillHiddenMs"
-                        }, null, null, null),
-                    new pbr::GeneratedClrTypeInfo(typeof(global::PokemonGo.RocketAPI.GeneratedCode.PokemonData),
-                        global::PokemonGo.RocketAPI.GeneratedCode.PokemonData.Parser,
-                        new[]
-                        {
-                            "Id", "PokemonId", "Cp", "Stamina", "StaminaMax", "Move1", "Move2", "DeployedFortId",
-                            "OwnerName", "IsEgg", "EggKmWalkedTarget", "EggKmWalkedStart", "Origin", "HeightM",
-                            "WeightKg", "IndividualAttack", "IndividualDefense", "IndividualStamina", "CpMultiplier",
-                            "Pokeball", "CapturedCellId", "BattlesAttacked", "BattlesDefended", "EggIncubatorId",
-                            "CreationTimeMs", "NumUpgrades", "AdditionalCpMultiplier", "Favorite", "Nickname",
-                            "FromFort"
-                        }, null, null, null),
-                    new pbr::GeneratedClrTypeInfo(typeof(global::PokemonGo.RocketAPI.GeneratedCode.MapPokemon),
-                        global::PokemonGo.RocketAPI.GeneratedCode.MapPokemon.Parser,
-                        new[]
-                        {"SpawnpointId", "EncounterId", "PokemonId", "ExpirationTimestampMs", "Latitude", "Longitude"},
-                        null, null, null),
-                    new pbr::GeneratedClrTypeInfo(typeof(global::PokemonGo.RocketAPI.GeneratedCode.NearbyPokemon),
-                        global::PokemonGo.RocketAPI.GeneratedCode.NearbyPokemon.Parser,
-                        new[] {"PokemonId", "DistanceInMeters", "EncounterId"}, null, null, null),
-                    new pbr::GeneratedClrTypeInfo(
-                        typeof(global::PokemonGo.RocketAPI.GeneratedCode.DownloadSettingsResponse),
-                        global::PokemonGo.RocketAPI.GeneratedCode.DownloadSettingsResponse.Parser,
-                        new[] {"Error", "Hash", "Settings"}, null, null, null),
-                    new pbr::GeneratedClrTypeInfo(typeof(global::PokemonGo.RocketAPI.GeneratedCode.GlobalSettings),
-                        global::PokemonGo.RocketAPI.GeneratedCode.GlobalSettings.Parser,
-                        new[]
-                        {"FortSettings", "MapSettings", "LevelSettings", "InventorySettings", "MinimumClientVersion"},
-                        null, null, null),
-                    new pbr::GeneratedClrTypeInfo(typeof(global::PokemonGo.RocketAPI.GeneratedCode.FortSettings),
-                        global::PokemonGo.RocketAPI.GeneratedCode.FortSettings.Parser,
-                        new[]
-                        {
-                            "InteractionRangeMeters", "MaxTotalDeployedPokemon", "MaxPlayerDeployedPokemon",
-                            "DeployStaminaMultiplier", "DeployAttackMultiplier", "FarInteractionRangeMeters"
-                        }, null,
-                        null, null),
-                    new pbr::GeneratedClrTypeInfo(typeof(global::PokemonGo.RocketAPI.GeneratedCode.MapSettings),
-                        global::PokemonGo.RocketAPI.GeneratedCode.MapSettings.Parser,
-                        new[]
-                        {
-                            "PokemonVisibleRange", "PokeNavRangeMeters", "EncounterRangeMeters",
-                            "GetMapObjectsMinRefreshSeconds", "GetMapObjectsMaxRefreshSeconds",
-                            "GetMapObjectsMinDistanceMeters", "GoogleMapsApiKey"
-                        }, null, null, null),
-                    new pbr::GeneratedClrTypeInfo(typeof(global::PokemonGo.RocketAPI.GeneratedCode.LevelSettings),
-                        global::PokemonGo.RocketAPI.GeneratedCode.LevelSettings.Parser,
-                        new[] {"TrainerCpModifier", "TrainerDifficultyModifier"}, null, null, null),
-                    new pbr::GeneratedClrTypeInfo(typeof(global::PokemonGo.RocketAPI.GeneratedCode.InventorySettings),
-                        global::PokemonGo.RocketAPI.GeneratedCode.InventorySettings.Parser,
-                        new[] {"MaxPokemon", "MaxBagItems", "BasePokemon", "BaseBagItems", "BaseEggs"}, null, null, null),
-                    new pbr::GeneratedClrTypeInfo(
-                        typeof(global::PokemonGo.RocketAPI.GeneratedCode.PlayerUpdateRequest),
-                        global::PokemonGo.RocketAPI.GeneratedCode.PlayerUpdateRequest.Parser,
-                        new[] {"Latitude", "Longitude"}, null, null, null),
-                    new pbr::GeneratedClrTypeInfo(
-                        typeof(global::PokemonGo.RocketAPI.GeneratedCode.PlayerUpdateResponse),
-                        global::PokemonGo.RocketAPI.GeneratedCode.PlayerUpdateResponse.Parser,
-                        new[] {"WildPokemons", "Forts", "FortsNearby"}, null, null, null),
-                    new pbr::GeneratedClrTypeInfo(
-                        typeof(global::PokemonGo.RocketAPI.GeneratedCode.DownloadItemTemplatesRequest),
-                        global::PokemonGo.RocketAPI.GeneratedCode.DownloadItemTemplatesRequest.Parser, null, null, null,
-                        null),
-                    new pbr::GeneratedClrTypeInfo(
-                        typeof(global::PokemonGo.RocketAPI.GeneratedCode.DownloadItemTemplatesResponse),
-                        global::PokemonGo.RocketAPI.GeneratedCode.DownloadItemTemplatesResponse.Parser,
-                        new[] {"Success", "ItemTemplates", "TimestampMs"}, null, null,
-                        new pbr::GeneratedClrTypeInfo[]
-                        {
-                            new pbr::GeneratedClrTypeInfo(
-                                typeof(
-                                    global::PokemonGo.RocketAPI.GeneratedCode.DownloadItemTemplatesResponse.Types.
-                                        ItemTemplate),
-                                global::PokemonGo.RocketAPI.GeneratedCode.DownloadItemTemplatesResponse.Types
-                                    .ItemTemplate.Parser,
-                                new[]
-                                {
-                                    "TemplateId", "PokemonSettings", "ItemSettings", "MoveSettings", "MoveSequenceSettings",
-                                    "TypeEffective", "BadgeSettings", "Camera", "PlayerLevel", "GymLevel",
-                                    "BattleSettings", "EncounterSettings", "IapItemDisplay", "IapSettings",
-                                    "PokemonUpgrades", "EquippedBadges"
-                                }, null, null, null)
-                        }),
-                    new pbr::GeneratedClrTypeInfo(
-                        typeof(global::PokemonGo.RocketAPI.GeneratedCode.UseItemCaptureRequest),
-                        global::PokemonGo.RocketAPI.GeneratedCode.UseItemCaptureRequest.Parser,
-                        new[] {"ItemId", "EncounterId", "SpawnPointGuid"}, null, null, null),
-                    new pbr::GeneratedClrTypeInfo(
-                        typeof(global::PokemonGo.RocketAPI.GeneratedCode.UseItemCaptureResponse),
-                        global::PokemonGo.RocketAPI.GeneratedCode.UseItemCaptureResponse.Parser,
-                        new[]
-                        {
-                            "Success", "ItemCaptureMult", "ItemFleeMult", "StopMovement", "StopAttack", "TargetMax",
-                            "TargetSlow"
-                        }, null, null, null),
-                    new pbr::GeneratedClrTypeInfo(
-                        typeof(global::PokemonGo.RocketAPI.GeneratedCode.ReleasePokemonRequest),
-                        global::PokemonGo.RocketAPI.GeneratedCode.ReleasePokemonRequest.Parser, new[] {"PokemonId"},
-                        null, null, null),
-                    new pbr::GeneratedClrTypeInfo(
-                        typeof(global::PokemonGo.RocketAPI.GeneratedCode.ReleasePokemonResponse),
-                        global::PokemonGo.RocketAPI.GeneratedCode.ReleasePokemonResponse.Parser,
-                        new[] {"Result", "CandyAwarded"}, null,
-                        new[] {typeof(global::PokemonGo.RocketAPI.GeneratedCode.ReleasePokemonResponse.Types.Result)},
-                        null),
-                    new pbr::GeneratedClrTypeInfo(
-                        typeof(global::PokemonGo.RocketAPI.GeneratedCode.GetHatchedEggsRequest),
-                        global::PokemonGo.RocketAPI.GeneratedCode.GetHatchedEggsRequest.Parser, null, null, null, null),
-                    new pbr::GeneratedClrTypeInfo(
-                        typeof(global::PokemonGo.RocketAPI.GeneratedCode.GetHatchedEggsResponse),
-                        global::PokemonGo.RocketAPI.GeneratedCode.GetHatchedEggsResponse.Parser,
-                        new[] {"Success", "PokemonId", "ExperienceAwarded", "CandyAwarded", "StardustAwarded"}, null,
-                        null, null),
-                    new pbr::GeneratedClrTypeInfo(typeof(global::PokemonGo.RocketAPI.GeneratedCode.FortSearchRequest),
-                        global::PokemonGo.RocketAPI.GeneratedCode.FortSearchRequest.Parser,
-                        new[] {"FortId", "PlayerLatitude", "PlayerLongitude", "FortLatitude", "FortLongitude"}, null,
-                        null, null),
-                    new pbr::GeneratedClrTypeInfo(typeof(global::PokemonGo.RocketAPI.GeneratedCode.FortSearchResponse),
-                        global::PokemonGo.RocketAPI.GeneratedCode.FortSearchResponse.Parser,
-                        new[]
-                        {
-                            "Result", "ItemsAwarded", "GemsAwarded", "PokemonDataEgg", "ExperienceAwarded",
-                            "CooldownCompleteTimestampMs", "ChainHackSequenceNumber"
-                        }, null,
-                        new[] {typeof(global::PokemonGo.RocketAPI.GeneratedCode.FortSearchResponse.Types.Result)},
-                        new pbr::GeneratedClrTypeInfo[]
-                        {
-                            new pbr::GeneratedClrTypeInfo(
-                                typeof(global::PokemonGo.RocketAPI.GeneratedCode.FortSearchResponse.Types.ItemAward),
-                                global::PokemonGo.RocketAPI.GeneratedCode.FortSearchResponse.Types.ItemAward.Parser,
-                                new[] {"ItemId", "ItemCount"}, null, null, null)
-                        }),
-                    new pbr::GeneratedClrTypeInfo(typeof(global::PokemonGo.RocketAPI.GeneratedCode.FortDetailsRequest),
-                        global::PokemonGo.RocketAPI.GeneratedCode.FortDetailsRequest.Parser,
-                        new[] {"FortId", "Latitude", "Longitude"}, null, null, null),
-                    new pbr::GeneratedClrTypeInfo(
-                        typeof(global::PokemonGo.RocketAPI.GeneratedCode.FortDetailsResponse),
-                        global::PokemonGo.RocketAPI.GeneratedCode.FortDetailsResponse.Parser,
-                        new[]
-                        {
-                            "FortId", "TeamColor", "PokemonData", "Name", "ImageUrls", "Fp", "Stamina", "MaxStamina",
-                            "Type", "Latitude", "Longitude", "Description", "Modifiers"
-                        }, null, null, null),
-                    new pbr::GeneratedClrTypeInfo(typeof(global::PokemonGo.RocketAPI.GeneratedCode.FortModifier),
-                        global::PokemonGo.RocketAPI.GeneratedCode.FortModifier.Parser,
-                        new[] {"ItemId", "ExpirationTimestampMs", "DeployerPlayerCodename"}, null, null, null),
-                    new pbr::GeneratedClrTypeInfo(typeof(global::PokemonGo.RocketAPI.GeneratedCode.EncounterRequest),
-                        global::PokemonGo.RocketAPI.GeneratedCode.EncounterRequest.Parser,
-                        new[] {"EncounterId", "SpawnpointId", "PlayerLatitude", "PlayerLongitude"}, null, null, null),
-                    new pbr::GeneratedClrTypeInfo(typeof(global::PokemonGo.RocketAPI.GeneratedCode.EncounterResponse),
-                        global::PokemonGo.RocketAPI.GeneratedCode.EncounterResponse.Parser,
-                        new[] {"WildPokemon", "Background", "Status", "CaptureProbability"}, null,
-                        new[]
-                        {
-                            typeof(global::PokemonGo.RocketAPI.GeneratedCode.EncounterResponse.Types.Background),
-                            typeof(global::PokemonGo.RocketAPI.GeneratedCode.EncounterResponse.Types.Status)
-                        }, null),
-                    new pbr::GeneratedClrTypeInfo(typeof(global::PokemonGo.RocketAPI.GeneratedCode.CaptureProbability),
-                        global::PokemonGo.RocketAPI.GeneratedCode.CaptureProbability.Parser,
-                        new[] {"PokeballType", "CaptureProbability_", "ReticleDifficultyScale"}, null, null, null),
-                    new pbr::GeneratedClrTypeInfo(
-                        typeof(global::PokemonGo.RocketAPI.GeneratedCode.DiskEncounterRequest),
-                        global::PokemonGo.RocketAPI.GeneratedCode.DiskEncounterRequest.Parser,
-                        new[] {"EncounterId", "FortId", "PlayerLatitude", "PlayerLongitude"}, null, null, null),
-                    new pbr::GeneratedClrTypeInfo(
-                        typeof(global::PokemonGo.RocketAPI.GeneratedCode.DiskEncounterResponse),
-                        global::PokemonGo.RocketAPI.GeneratedCode.DiskEncounterResponse.Parser,
-                        new[] {"Result", "PokemonData", "CaptureProbability"}, null,
-                        new[] {typeof(global::PokemonGo.RocketAPI.GeneratedCode.DiskEncounterResponse.Types.Result)},
-                        null),
-                    new pbr::GeneratedClrTypeInfo(
-                        typeof(global::PokemonGo.RocketAPI.GeneratedCode.CatchPokemonRequest),
-                        global::PokemonGo.RocketAPI.GeneratedCode.CatchPokemonRequest.Parser,
-                        new[]
-                        {
-                            "EncounterId", "Pokeball", "NormalizedReticleSize", "SpawnPointGuid", "HitPokemon",
-                            "SpinModifier", "NormalizedHitPosition"
-                        }, null, null, null),
-                    new pbr::GeneratedClrTypeInfo(
-                        typeof(global::PokemonGo.RocketAPI.GeneratedCode.CatchPokemonResponse),
-                        global::PokemonGo.RocketAPI.GeneratedCode.CatchPokemonResponse.Parser,
-                        new[] {"Status", "MissPercent", "CapturedPokemonId", "Scores"}, null,
-                        new[] {typeof(global::PokemonGo.RocketAPI.GeneratedCode.CatchPokemonResponse.Types.CatchStatus)},
-                        null),
-                    new pbr::GeneratedClrTypeInfo(typeof(global::PokemonGo.RocketAPI.GeneratedCode.CaptureScore),
-                        global::PokemonGo.RocketAPI.GeneratedCode.CaptureScore.Parser,
-                        new[] {"ActivityType", "Xp", "Candy", "Stardust"}, null, null, null),
-                    new pbr::GeneratedClrTypeInfo(
-                        typeof(global::PokemonGo.RocketAPI.GeneratedCode.CheckAwardedBadgesRequest),
-                        global::PokemonGo.RocketAPI.GeneratedCode.CheckAwardedBadgesRequest.Parser, null, null, null,
-                        null),
-                    new pbr::GeneratedClrTypeInfo(
-                        typeof(global::PokemonGo.RocketAPI.GeneratedCode.CheckAwardedBadgesResponse),
-                        global::PokemonGo.RocketAPI.GeneratedCode.CheckAwardedBadgesResponse.Parser,
-                        new[] {"Success", "AwardedBadges", "AwardedBadgeLevels"}, null, null, null),
-                    new pbr::GeneratedClrTypeInfo(
-                        typeof(global::PokemonGo.RocketAPI.GeneratedCode.EquippedBadgeSettings),
-                        global::PokemonGo.RocketAPI.GeneratedCode.EquippedBadgeSettings.Parser,
-                        new[] {"EquipBadgeCooldownMs", "CatchProbabilityBonus", "FleeProbabilityBonus"}, null, null,
-                        null),
-                    new pbr::GeneratedClrTypeInfo(
-                        typeof(global::PokemonGo.RocketAPI.GeneratedCode.PokemonUpgradeSettings),
-                        global::PokemonGo.RocketAPI.GeneratedCode.PokemonUpgradeSettings.Parser,
-                        new[] {"UpgradesPerLevel", "AllowedLevelsAbovePlayer", "CandyCost", "StardustCost"}, null, null,
-                        null),
-                    new pbr::GeneratedClrTypeInfo(typeof(global::PokemonGo.RocketAPI.GeneratedCode.IapSettings),
-                        global::PokemonGo.RocketAPI.GeneratedCode.IapSettings.Parser,
-                        new[]
-                        {
-                            "DailyBonusCoins", "DailyDefenderBonusPerPokemon", "DailyDefenderBonusMaxDefenders",
-                            "DailyDefenderBonusCurrency", "MinTimeBetweenClaimsMs", "DailyBonusEnabled",
-                            "DailyDefenderBonusEnabled"
-                        }, null, null, null),
-                    new pbr::GeneratedClrTypeInfo(typeof(global::PokemonGo.RocketAPI.GeneratedCode.IapItemDisplay),
-                        global::PokemonGo.RocketAPI.GeneratedCode.IapItemDisplay.Parser,
-                        new[] {"Sku", "Category", "SortOrder", "ItemIds", "Counts"}, null, null, null),
-                    new pbr::GeneratedClrTypeInfo(typeof(global::PokemonGo.RocketAPI.GeneratedCode.EncounterSettings),
-                        global::PokemonGo.RocketAPI.GeneratedCode.EncounterSettings.Parser,
-                        new[]
-                        {
-                            "SpinBonusThreshold", "ExcellentThrowThreshold", "GreatThrowThreshold", "NiceThrowThreshold",
-                            "MilestoneThreshold"
-                        }, null, null, null),
-                    new pbr::GeneratedClrTypeInfo(typeof(global::PokemonGo.RocketAPI.GeneratedCode.GymBattleSettings),
-                        global::PokemonGo.RocketAPI.GeneratedCode.GymBattleSettings.Parser,
-                        new[]
-                        {
-                            "EnergyPerSec", "DodgeEnergyCost", "RetargetSeconds", "EnemyAttackInterval",
-                            "AttackServerInterval", "RoundDurationSeconds", "BonusTimePerAllySeconds",
-                            "MaximumAttackersPerBattle", "SameTypeAttackBonusMultiplier", "MaximumEnergy",
-                            "EnergyDeltaPerHealthLost", "DodgeDurationMs", "MinimumPlayerLevel", "SwapDurationMs"
-                        }, null,
-                        null, null),
-                    new pbr::GeneratedClrTypeInfo(typeof(global::PokemonGo.RocketAPI.GeneratedCode.GymLevelSettings),
-                        global::PokemonGo.RocketAPI.GeneratedCode.GymLevelSettings.Parser,
-                        new[] {"RequiredExperience", "LeaderSlots", "TrainerSlots", "SearchRollBonus"}, null, null, null),
-                    new pbr::GeneratedClrTypeInfo(
-                        typeof(global::PokemonGo.RocketAPI.GeneratedCode.PlayerLevelSettings),
-                        global::PokemonGo.RocketAPI.GeneratedCode.PlayerLevelSettings.Parser,
-                        new[]
-                        {
-                            "RankNum", "RequiredExperience", "CpMultiplier", "MaxEggPlayerLevel", "MaxEncounterPlayerLevel"
-                        }, null, null, null),
-                    new pbr::GeneratedClrTypeInfo(typeof(global::PokemonGo.RocketAPI.GeneratedCode.CameraSettings),
-                        global::PokemonGo.RocketAPI.GeneratedCode.CameraSettings.Parser,
-                        new[]
-                        {
-                            "NextCamera", "Interpolation", "TargetType", "EaseInSpeed", "EastOutSpeed", "DurationSeconds",
-                            "WaitSeconds", "TransitionSeconds", "AngleDegree", "AngleOffsetDegree", "PitchDegree",
-                            "PitchOffsetDegree", "RollDegree", "DistanceMeters", "HeightPercent", "VertCtrRatio"
-                        }, null,
-                        null, null),
-                    new pbr::GeneratedClrTypeInfo(typeof(global::PokemonGo.RocketAPI.GeneratedCode.BadgeSettings),
-                        global::PokemonGo.RocketAPI.GeneratedCode.BadgeSettings.Parser,
-                        new[] {"BadgeType", "BadgeRank", "Targets"}, null, null, null),
-                    new pbr::GeneratedClrTypeInfo(
-                        typeof(global::PokemonGo.RocketAPI.GeneratedCode.TypeEffectiveSettings),
-                        global::PokemonGo.RocketAPI.GeneratedCode.TypeEffectiveSettings.Parser,
-                        new[] {"AttackScalar", "AttackType"}, null, null, null),
-                    new pbr::GeneratedClrTypeInfo(
-                        typeof(global::PokemonGo.RocketAPI.GeneratedCode.MoveSequenceSettings),
-                        global::PokemonGo.RocketAPI.GeneratedCode.MoveSequenceSettings.Parser, new[] {"Sequence"}, null,
-                        null, null),
-                    new pbr::GeneratedClrTypeInfo(typeof(global::PokemonGo.RocketAPI.GeneratedCode.MoveSettings),
-                        global::PokemonGo.RocketAPI.GeneratedCode.MoveSettings.Parser,
-                        new[]
-                        {
-                            "MovementId", "AnimationId", "PokemonType", "Power", "AccuracyChance", "CriticalChance",
-                            "HealScalar", "StaminaLossScalar", "TrainerLevelMin", "TrainerLevelMax", "VfxName",
-                            "DurationMs", "DamageWindowStartMs", "DamageWindowEndMs", "EnergyDelta"
-                        }, null, null, null),
-                    new pbr::GeneratedClrTypeInfo(typeof(global::PokemonGo.RocketAPI.GeneratedCode.PokemonSettings),
-                        global::PokemonGo.RocketAPI.GeneratedCode.PokemonSettings.Parser,
-                        new[]
-                        {
-                            "PokemonId", "ModelScale", "Type", "Type2", "Camera", "Encounter", "Stats", "QuickMoves",
-                            "CinematicMoves", "AnimationTime", "EvolutionIds", "EvolutionPips", "Class",
-                            "PokedexHeightM", "PokedexWeightKg", "ParentPokemonId", "HeightStdDev", "WeightStdDev",
-                            "KmDistanceToHatch", "FamilyId", "CandyToEvolve"
-                        }, null, null, null),
-                    new pbr::GeneratedClrTypeInfo(typeof(global::PokemonGo.RocketAPI.GeneratedCode.CameraAttributes),
-                        global::PokemonGo.RocketAPI.GeneratedCode.CameraAttributes.Parser,
-                        new[]
-                        {"DiskRadiusM", "CylinderRadiusM", "CylinderHeightM", "CylinderGroundM", "ShoulderModeScale"},
-                        null, null, null),
-                    new pbr::GeneratedClrTypeInfo(
-                        typeof(global::PokemonGo.RocketAPI.GeneratedCode.EncounterAttributes),
-                        global::PokemonGo.RocketAPI.GeneratedCode.EncounterAttributes.Parser,
-                        new[]
-                        {
-                            "BaseCaptureRate", "BaseFleeRate", "CollisionRadiusM", "CollisionHeightM",
-                            "CollisionHeadRadiusM", "MovementType", "MovementTimerS", "JumpTimeS", "AttackTimerS"
-                        }, null,
-                        null, null),
-                    new pbr::GeneratedClrTypeInfo(typeof(global::PokemonGo.RocketAPI.GeneratedCode.StatsAttributes),
-                        global::PokemonGo.RocketAPI.GeneratedCode.StatsAttributes.Parser,
-                        new[] {"BaseStamina", "BaseAttack", "BaseDefense", "DodgeEnergyDelta"}, null, null, null),
-                    new pbr::GeneratedClrTypeInfo(typeof(global::PokemonGo.RocketAPI.GeneratedCode.ItemSettings),
-                        global::PokemonGo.RocketAPI.GeneratedCode.ItemSettings.Parser,
-                        new[]
-                        {
-                            "ItemId", "ItemType", "Category", "DropFreq", "DropTrainerLevel", "Pokeball", "Potion",
-                            "Revive", "Battle", "Food", "InventoryUpgrade", "XpBoost", "Incense", "EggIncubator",
-                            "FortModifier"
-                        }, null, null, null),
-                    new pbr::GeneratedClrTypeInfo(typeof(global::PokemonGo.RocketAPI.GeneratedCode.BattleAttributes),
-                        global::PokemonGo.RocketAPI.GeneratedCode.BattleAttributes.Parser, new[] {"StaPercent"}, null,
-                        null, null),
-                    new pbr::GeneratedClrTypeInfo(
-                        typeof(global::PokemonGo.RocketAPI.GeneratedCode.EggIncubatorAttributes),
-                        global::PokemonGo.RocketAPI.GeneratedCode.EggIncubatorAttributes.Parser,
-                        new[] {"IncubatorType", "Uses", "DistanceMultiplier"}, null, null, null),
-                    new pbr::GeneratedClrTypeInfo(
-                        typeof(global::PokemonGo.RocketAPI.GeneratedCode.ExperienceBoostAttributes),
-                        global::PokemonGo.RocketAPI.GeneratedCode.ExperienceBoostAttributes.Parser,
-                        new[] {"XpMultiplier", "BoostDurationMs"}, null, null, null),
-                    new pbr::GeneratedClrTypeInfo(typeof(global::PokemonGo.RocketAPI.GeneratedCode.FoodAttributes),
-                        global::PokemonGo.RocketAPI.GeneratedCode.FoodAttributes.Parser,
-                        new[] {"ItemEffect", "ItemEffectPercent", "GrowthPercent"}, null, null, null),
-                    new pbr::GeneratedClrTypeInfo(
-                        typeof(global::PokemonGo.RocketAPI.GeneratedCode.FortModifierAttributes),
-                        global::PokemonGo.RocketAPI.GeneratedCode.FortModifierAttributes.Parser,
-                        new[] {"ModifierLifetimeSeconds", "TroyDiskNumPokemonSpawned"}, null, null, null),
-                    new pbr::GeneratedClrTypeInfo(typeof(global::PokemonGo.RocketAPI.GeneratedCode.IncenseAttributes),
-                        global::PokemonGo.RocketAPI.GeneratedCode.IncenseAttributes.Parser,
-                        new[]
-                        {
-                            "IncenseLifetimeSeconds", "PokemonType", "PokemonIncenseTypeProbability",
-                            "StandingTimeBetweenEncountersSeconds", "MovingTimeBetweenEncounterSeconds",
-                            "DistanceRequiredForShorterIntervalMeters", "PokemonAttractedLengthSec"
-                        }, null, null, null),
-                    new pbr::GeneratedClrTypeInfo(
-                        typeof(global::PokemonGo.RocketAPI.GeneratedCode.InventoryUpgradeAttributes),
-                        global::PokemonGo.RocketAPI.GeneratedCode.InventoryUpgradeAttributes.Parser,
-                        new[] {"AdditionalStorage", "UpgradeType"}, null, null, null),
-                    new pbr::GeneratedClrTypeInfo(typeof(global::PokemonGo.RocketAPI.GeneratedCode.PokeballAttributes),
-                        global::PokemonGo.RocketAPI.GeneratedCode.PokeballAttributes.Parser,
-                        new[] {"ItemEffect", "CaptureMulti", "CaptureMultiEffect", "ItemEffectMod"}, null, null, null),
-                    new pbr::GeneratedClrTypeInfo(typeof(global::PokemonGo.RocketAPI.GeneratedCode.PotionAttributes),
-                        global::PokemonGo.RocketAPI.GeneratedCode.PotionAttributes.Parser,
-                        new[] {"StaPercent", "StaAmount"}, null, null, null),
-                    new pbr::GeneratedClrTypeInfo(typeof(global::PokemonGo.RocketAPI.GeneratedCode.ReviveAttributes),
-                        global::PokemonGo.RocketAPI.GeneratedCode.ReviveAttributes.Parser, new[] {"StaPercent"}, null,
-                        null, null),
-                    new pbr::GeneratedClrTypeInfo(typeof(global::PokemonGo.RocketAPI.GeneratedCode.TransferPokemon),
-                        global::PokemonGo.RocketAPI.GeneratedCode.TransferPokemon.Parser, new[] {"PokemonId"}, null,
-                        null, null),
-                    new pbr::GeneratedClrTypeInfo(typeof(global::PokemonGo.RocketAPI.GeneratedCode.TransferPokemonOut),
-                        global::PokemonGo.RocketAPI.GeneratedCode.TransferPokemonOut.Parser,
-                        new[] {"Status", "CandyAwarded"}, null, null, null),
-                    new pbr::GeneratedClrTypeInfo(typeof(global::PokemonGo.RocketAPI.GeneratedCode.EvolvePokemon),
-                        global::PokemonGo.RocketAPI.GeneratedCode.EvolvePokemon.Parser, new[] {"PokemonId"}, null, null,
-                        null),
-                    new pbr::GeneratedClrTypeInfo(typeof(global::PokemonGo.RocketAPI.GeneratedCode.EvolvePokemonOut),
-                        global::PokemonGo.RocketAPI.GeneratedCode.EvolvePokemonOut.Parser,
-                        new[] {"Result", "EvolvedPokemon", "ExpAwarded", "CandyAwarded"}, null,
-                        new[]
-                        {typeof(global::PokemonGo.RocketAPI.GeneratedCode.EvolvePokemonOut.Types.EvolvePokemonStatus)},
-                        null)
-                }));
-        }
-
-        #endregion
-    }
-
-    #region Messages
-
-    [global::System.Diagnostics.DebuggerNonUserCodeAttribute()]
-    public sealed partial class GetPlayerResponse : pb::IMessage<GetPlayerResponse>
-    {
-        /// <summary>Field number for the "unknown1" field.</summary>
-        public const int Unknown1FieldNumber = 1;
-
-        /// <summary>Field number for the "profile" field.</summary>
-        public const int ProfileFieldNumber = 2;
-
-        private static readonly pb::MessageParser<GetPlayerResponse> _parser =
-            new pb::MessageParser<GetPlayerResponse>(() => new GetPlayerResponse());
-
-        private global::PokemonGo.RocketAPI.GeneratedCode.Profile profile_;
-        private int unknown1_;
-
-        public GetPlayerResponse()
-        {
-            OnConstruction();
-        }
-
-        public GetPlayerResponse(GetPlayerResponse other) : this()
-        {
-            unknown1_ = other.unknown1_;
-            Profile = other.profile_ != null ? other.Profile.Clone() : null;
-        }
-
-        public static pb::MessageParser<GetPlayerResponse> Parser
-        {
-            get { return _parser; }
-        }
-
-        public static pbr::MessageDescriptor Descriptor
-        {
-            get { return global::PokemonGo.RocketAPI.GeneratedCode.PayloadsReflection.Descriptor.MessageTypes[0]; }
-        }
-
-        public int Unknown1
-        {
-            get { return unknown1_; }
-            set { unknown1_ = value; }
-        }
-
-        public global::PokemonGo.RocketAPI.GeneratedCode.Profile Profile
-        {
-            get { return profile_; }
-            set { profile_ = value; }
-        }
-
-        pbr::MessageDescriptor pb::IMessage.Descriptor
-        {
-            get { return Descriptor; }
-        }
-
-        public GetPlayerResponse Clone()
-        {
-            return new GetPlayerResponse(this);
-        }
-
-        public bool Equals(GetPlayerResponse other)
-        {
-            if (ReferenceEquals(other, null))
-            {
-                return false;
-            }
-            if (ReferenceEquals(other, this))
-            {
-                return true;
-            }
-            if (Unknown1 != other.Unknown1) return false;
-            if (!Equals(Profile, other.Profile)) return false;
-            return true;
-        }
-
-        public void WriteTo(pb::CodedOutputStream output)
-        {
-            if (Unknown1 != 0)
-            {
-                output.WriteRawTag(8);
-                output.WriteInt32(Unknown1);
-            }
-            if (profile_ != null)
-            {
-                output.WriteRawTag(18);
-                output.WriteMessage(Profile);
-            }
-        }
-
-        public int CalculateSize()
-        {
-            var size = 0;
-            if (Unknown1 != 0)
-            {
-                size += 1 + pb::CodedOutputStream.ComputeInt32Size(Unknown1);
-            }
-            if (profile_ != null)
-            {
-                size += 1 + pb::CodedOutputStream.ComputeMessageSize(Profile);
-            }
-            return size;
-        }
-
-        public void MergeFrom(GetPlayerResponse other)
-        {
-            if (other == null)
-            {
-                return;
-            }
-            if (other.Unknown1 != 0)
-            {
-                Unknown1 = other.Unknown1;
-            }
-            if (other.profile_ != null)
-            {
-                if (profile_ == null)
-                {
-                    profile_ = new global::PokemonGo.RocketAPI.GeneratedCode.Profile();
-                }
-                Profile.MergeFrom(other.Profile);
-            }
-        }
-
-        public void MergeFrom(pb::CodedInputStream input)
-        {
-            uint tag;
-            while ((tag = input.ReadTag()) != 0)
-            {
-                switch (tag)
-                {
-                    default:
-                        input.SkipLastField();
-                        break;
-                    case 8:
-                        {
-                            Unknown1 = input.ReadInt32();
-                            break;
-                        }
-                    case 18:
-                        {
-                            if (profile_ == null)
-                            {
-                                profile_ = new global::PokemonGo.RocketAPI.GeneratedCode.Profile();
-                            }
-                            input.ReadMessage(profile_);
-                            break;
-                        }
-                }
-            }
-        }
-
-        public override bool Equals(object other)
-        {
-            return Equals(other as GetPlayerResponse);
-        }
-
-        public override int GetHashCode()
-        {
-            var hash = 1;
-            if (Unknown1 != 0) hash ^= Unknown1.GetHashCode();
-            if (profile_ != null) hash ^= Profile.GetHashCode();
-            return hash;
-        }
-
-        partial void OnConstruction();
-
-        public override string ToString()
-        {
-            return pb::JsonFormatter.ToDiagnosticString(this);
-        }
-    }
-
-    [global::System.Diagnostics.DebuggerNonUserCodeAttribute()]
-    public sealed partial class Profile : pb::IMessage<Profile>
-    {
-        /// <summary>Field number for the "creation_time" field.</summary>
-        public const int CreationTimeFieldNumber = 1;
-
-        /// <summary>Field number for the "username" field.</summary>
-        public const int UsernameFieldNumber = 2;
-
-        /// <summary>Field number for the "team" field.</summary>
-        public const int TeamFieldNumber = 5;
-
-        /// <summary>Field number for the "tutorial" field.</summary>
-        public const int TutorialFieldNumber = 7;
-
-        /// <summary>Field number for the "avatar" field.</summary>
-        public const int AvatarFieldNumber = 8;
-
-        /// <summary>Field number for the "poke_storage" field.</summary>
-        public const int PokeStorageFieldNumber = 9;
-
-        /// <summary>Field number for the "item_storage" field.</summary>
-        public const int ItemStorageFieldNumber = 10;
-
-        /// <summary>Field number for the "daily_bonus" field.</summary>
-        public const int DailyBonusFieldNumber = 11;
-
-        /// <summary>Field number for the "unknown12" field.</summary>
-        public const int Unknown12FieldNumber = 12;
-
-        /// <summary>Field number for the "unknown13" field.</summary>
-        public const int Unknown13FieldNumber = 13;
-
-        /// <summary>Field number for the "currency" field.</summary>
-        public const int CurrencyFieldNumber = 14;
-
-        private static readonly pb::MessageParser<Profile> _parser = new pb::MessageParser<Profile>(() => new Profile());
-
-        private static readonly pb::FieldCodec<global::PokemonGo.RocketAPI.GeneratedCode.Currency>
-            _repeated_currency_codec
-                = pb::FieldCodec.ForMessage(114, global::PokemonGo.RocketAPI.GeneratedCode.Currency.Parser);
-
-        private readonly pbc::RepeatedField<global::PokemonGo.RocketAPI.GeneratedCode.Currency> currency_ =
-            new pbc::RepeatedField<global::PokemonGo.RocketAPI.GeneratedCode.Currency>();
-
-        private global::PokemonGo.RocketAPI.GeneratedCode.AvatarDetails avatar_;
-        private long creationTime_;
-        private global::PokemonGo.RocketAPI.GeneratedCode.DailyBonus dailyBonus_;
-        private int itemStorage_;
-        private int pokeStorage_;
-        private global::PokemonGo.RocketAPI.GeneratedCode.TeamColor team_ = 0;
-        private pb::ByteString tutorial_ = pb::ByteString.Empty;
-        private pb::ByteString unknown12_ = pb::ByteString.Empty;
-        private pb::ByteString unknown13_ = pb::ByteString.Empty;
-        private string username_ = "";
-
-        public Profile()
-        {
-            OnConstruction();
-        }
-
-        public Profile(Profile other) : this()
-        {
-            creationTime_ = other.creationTime_;
-            username_ = other.username_;
-            team_ = other.team_;
-            tutorial_ = other.tutorial_;
-            Avatar = other.avatar_ != null ? other.Avatar.Clone() : null;
-            pokeStorage_ = other.pokeStorage_;
-            itemStorage_ = other.itemStorage_;
-            DailyBonus = other.dailyBonus_ != null ? other.DailyBonus.Clone() : null;
-            unknown12_ = other.unknown12_;
-            unknown13_ = other.unknown13_;
-            currency_ = other.currency_.Clone();
-        }
-
-        public static pb::MessageParser<Profile> Parser
-        {
-            get { return _parser; }
-        }
-
-        public static pbr::MessageDescriptor Descriptor
-        {
-            get { return global::PokemonGo.RocketAPI.GeneratedCode.PayloadsReflection.Descriptor.MessageTypes[1]; }
-        }
-
-        public long CreationTime
-        {
-            get { return creationTime_; }
-            set { creationTime_ = value; }
-        }
-
-        public string Username
-        {
-            get { return username_; }
-            set { username_ = pb::ProtoPreconditions.CheckNotNull(value, "value"); }
-        }
-
-        public global::PokemonGo.RocketAPI.GeneratedCode.TeamColor Team
-        {
-            get { return team_; }
-            set { team_ = value; }
-        }
-
-        public pb::ByteString Tutorial
-        {
-            get { return tutorial_; }
-            set { tutorial_ = pb::ProtoPreconditions.CheckNotNull(value, "value"); }
-        }
-
-        public global::PokemonGo.RocketAPI.GeneratedCode.AvatarDetails Avatar
-        {
-            get { return avatar_; }
-            set { avatar_ = value; }
-        }
-
-        public int PokeStorage
-        {
-            get { return pokeStorage_; }
-            set { pokeStorage_ = value; }
-        }
-
-        public int ItemStorage
-        {
-            get { return itemStorage_; }
-            set { itemStorage_ = value; }
-        }
-
-        public global::PokemonGo.RocketAPI.GeneratedCode.DailyBonus DailyBonus
-        {
-            get { return dailyBonus_; }
-            set { dailyBonus_ = value; }
-        }
-
-        public pb::ByteString Unknown12
-        {
-            get { return unknown12_; }
-            set { unknown12_ = pb::ProtoPreconditions.CheckNotNull(value, "value"); }
-        }
-
-        public pb::ByteString Unknown13
-        {
-            get { return unknown13_; }
-            set { unknown13_ = pb::ProtoPreconditions.CheckNotNull(value, "value"); }
-        }
-
-        public pbc::RepeatedField<global::PokemonGo.RocketAPI.GeneratedCode.Currency> Currency
-        {
-            get { return currency_; }
-        }
-
-        pbr::MessageDescriptor pb::IMessage.Descriptor
-        {
-            get { return Descriptor; }
-        }
-
-        public Profile Clone()
-        {
-            return new Profile(this);
-        }
-
-        public bool Equals(Profile other)
-        {
-            if (ReferenceEquals(other, null))
-            {
-                return false;
-            }
-            if (ReferenceEquals(other, this))
-            {
-                return true;
-            }
-            if (CreationTime != other.CreationTime) return false;
-            if (Username != other.Username) return false;
-            if (Team != other.Team) return false;
-            if (Tutorial != other.Tutorial) return false;
-            if (!Equals(Avatar, other.Avatar)) return false;
-            if (PokeStorage != other.PokeStorage) return false;
-            if (ItemStorage != other.ItemStorage) return false;
-            if (!Equals(DailyBonus, other.DailyBonus)) return false;
-            if (Unknown12 != other.Unknown12) return false;
-            if (Unknown13 != other.Unknown13) return false;
-            if (!currency_.Equals(other.currency_)) return false;
-            return true;
-        }
-
-        public void WriteTo(pb::CodedOutputStream output)
-        {
-            if (CreationTime != 0L)
-            {
-                output.WriteRawTag(8);
-                output.WriteInt64(CreationTime);
-            }
-            if (Username.Length != 0)
-            {
-                output.WriteRawTag(18);
-                output.WriteString(Username);
-            }
-            if (Team != 0)
-            {
-                output.WriteRawTag(40);
-                output.WriteEnum((int)Team);
-            }
-            if (Tutorial.Length != 0)
-            {
-                output.WriteRawTag(58);
-                output.WriteBytes(Tutorial);
-            }
-            if (avatar_ != null)
-            {
-                output.WriteRawTag(66);
-                output.WriteMessage(Avatar);
-            }
-            if (PokeStorage != 0)
-            {
-                output.WriteRawTag(72);
-                output.WriteInt32(PokeStorage);
-            }
-            if (ItemStorage != 0)
-            {
-                output.WriteRawTag(80);
-                output.WriteInt32(ItemStorage);
-            }
-            if (dailyBonus_ != null)
-            {
-                output.WriteRawTag(90);
-                output.WriteMessage(DailyBonus);
-            }
-            if (Unknown12.Length != 0)
-            {
-                output.WriteRawTag(98);
-                output.WriteBytes(Unknown12);
-            }
-            if (Unknown13.Length != 0)
-            {
-                output.WriteRawTag(106);
-                output.WriteBytes(Unknown13);
-            }
-            currency_.WriteTo(output, _repeated_currency_codec);
-        }
-
-        public int CalculateSize()
-        {
-            var size = 0;
-            if (CreationTime != 0L)
-            {
-                size += 1 + pb::CodedOutputStream.ComputeInt64Size(CreationTime);
-            }
-            if (Username.Length != 0)
-            {
-                size += 1 + pb::CodedOutputStream.ComputeStringSize(Username);
-            }
-            if (Team != 0)
-            {
-                size += 1 + pb::CodedOutputStream.ComputeEnumSize((int)Team);
-            }
-            if (Tutorial.Length != 0)
-            {
-                size += 1 + pb::CodedOutputStream.ComputeBytesSize(Tutorial);
-            }
-            if (avatar_ != null)
-            {
-                size += 1 + pb::CodedOutputStream.ComputeMessageSize(Avatar);
-            }
-            if (PokeStorage != 0)
-            {
-                size += 1 + pb::CodedOutputStream.ComputeInt32Size(PokeStorage);
-            }
-            if (ItemStorage != 0)
-            {
-                size += 1 + pb::CodedOutputStream.ComputeInt32Size(ItemStorage);
-            }
-            if (dailyBonus_ != null)
-            {
-                size += 1 + pb::CodedOutputStream.ComputeMessageSize(DailyBonus);
-            }
-            if (Unknown12.Length != 0)
-            {
-                size += 1 + pb::CodedOutputStream.ComputeBytesSize(Unknown12);
-            }
-            if (Unknown13.Length != 0)
-            {
-                size += 1 + pb::CodedOutputStream.ComputeBytesSize(Unknown13);
-            }
-            size += currency_.CalculateSize(_repeated_currency_codec);
-            return size;
-        }
-
-        public void MergeFrom(Profile other)
-        {
-            if (other == null)
-            {
-                return;
-            }
-            if (other.CreationTime != 0L)
-            {
-                CreationTime = other.CreationTime;
-            }
-            if (other.Username.Length != 0)
-            {
-                Username = other.Username;
-            }
-            if (other.Team != 0)
-            {
-                Team = other.Team;
-            }
-            if (other.Tutorial.Length != 0)
-            {
-                Tutorial = other.Tutorial;
-            }
-            if (other.avatar_ != null)
-            {
-                if (avatar_ == null)
-                {
-                    avatar_ = new global::PokemonGo.RocketAPI.GeneratedCode.AvatarDetails();
-                }
-                Avatar.MergeFrom(other.Avatar);
-            }
-            if (other.PokeStorage != 0)
-            {
-                PokeStorage = other.PokeStorage;
-            }
-            if (other.ItemStorage != 0)
-            {
-                ItemStorage = other.ItemStorage;
-            }
-            if (other.dailyBonus_ != null)
-            {
-                if (dailyBonus_ == null)
-                {
-                    dailyBonus_ = new global::PokemonGo.RocketAPI.GeneratedCode.DailyBonus();
-                }
-                DailyBonus.MergeFrom(other.DailyBonus);
-            }
-            if (other.Unknown12.Length != 0)
-            {
-                Unknown12 = other.Unknown12;
-            }
-            if (other.Unknown13.Length != 0)
-            {
-                Unknown13 = other.Unknown13;
-            }
-            currency_.Add(other.currency_);
-        }
-
-        public void MergeFrom(pb::CodedInputStream input)
-        {
-            uint tag;
-            while ((tag = input.ReadTag()) != 0)
-            {
-                switch (tag)
-                {
-                    default:
-                        input.SkipLastField();
-                        break;
-                    case 8:
-                        {
-                            CreationTime = input.ReadInt64();
-                            break;
-                        }
-                    case 18:
-                        {
-                            Username = input.ReadString();
-                            break;
-                        }
-                    case 40:
-                        {
-                            team_ = (global::PokemonGo.RocketAPI.GeneratedCode.TeamColor)input.ReadEnum();
-                            break;
-                        }
-                    case 58:
-                        {
-                            Tutorial = input.ReadBytes();
-                            break;
-                        }
-                    case 66:
-                        {
-                            if (avatar_ == null)
-                            {
-                                avatar_ = new global::PokemonGo.RocketAPI.GeneratedCode.AvatarDetails();
-                            }
-                            input.ReadMessage(avatar_);
-                            break;
-                        }
-                    case 72:
-                        {
-                            PokeStorage = input.ReadInt32();
-                            break;
-                        }
-                    case 80:
-                        {
-                            ItemStorage = input.ReadInt32();
-                            break;
-                        }
-                    case 90:
-                        {
-                            if (dailyBonus_ == null)
-                            {
-                                dailyBonus_ = new global::PokemonGo.RocketAPI.GeneratedCode.DailyBonus();
-                            }
-                            input.ReadMessage(dailyBonus_);
-                            break;
-                        }
-                    case 98:
-                        {
-                            Unknown12 = input.ReadBytes();
-                            break;
-                        }
-                    case 106:
-                        {
-                            Unknown13 = input.ReadBytes();
-                            break;
-                        }
-                    case 114:
-                        {
-                            currency_.AddEntriesFrom(input, _repeated_currency_codec);
-                            break;
-                        }
-                }
-            }
-        }
-
-        public override bool Equals(object other)
-        {
-            return Equals(other as Profile);
-        }
-
-        public override int GetHashCode()
-        {
-            var hash = 1;
-            if (CreationTime != 0L) hash ^= CreationTime.GetHashCode();
-            if (Username.Length != 0) hash ^= Username.GetHashCode();
-            if (Team != 0) hash ^= Team.GetHashCode();
-            if (Tutorial.Length != 0) hash ^= Tutorial.GetHashCode();
-            if (avatar_ != null) hash ^= Avatar.GetHashCode();
-            if (PokeStorage != 0) hash ^= PokeStorage.GetHashCode();
-            if (ItemStorage != 0) hash ^= ItemStorage.GetHashCode();
-            if (dailyBonus_ != null) hash ^= DailyBonus.GetHashCode();
-            if (Unknown12.Length != 0) hash ^= Unknown12.GetHashCode();
-            if (Unknown13.Length != 0) hash ^= Unknown13.GetHashCode();
-            hash ^= currency_.GetHashCode();
-            return hash;
-        }
-
-        partial void OnConstruction();
-
-        public override string ToString()
-        {
-            return pb::JsonFormatter.ToDiagnosticString(this);
-        }
-    }
-
-    [global::System.Diagnostics.DebuggerNonUserCodeAttribute()]
-    public sealed partial class DailyBonus : pb::IMessage<DailyBonus>
-    {
-        /// <summary>Field number for the "NextCollectTimestampMs" field.</summary>
-        public const int NextCollectTimestampMsFieldNumber = 1;
-
-        /// <summary>Field number for the "NextDefenderBonusCollectTimestampMs" field.</summary>
-        public const int NextDefenderBonusCollectTimestampMsFieldNumber = 2;
-
-        private static readonly pb::MessageParser<DailyBonus> _parser =
-            new pb::MessageParser<DailyBonus>(() => new DailyBonus());
-
-        private long nextCollectTimestampMs_;
-        private long nextDefenderBonusCollectTimestampMs_;
-
-        public DailyBonus()
-        {
-            OnConstruction();
-        }
-
-        public DailyBonus(DailyBonus other) : this()
-        {
-            nextCollectTimestampMs_ = other.nextCollectTimestampMs_;
-            nextDefenderBonusCollectTimestampMs_ = other.nextDefenderBonusCollectTimestampMs_;
-        }
-
-        public static pb::MessageParser<DailyBonus> Parser
-        {
-            get { return _parser; }
-        }
-
-        public static pbr::MessageDescriptor Descriptor
-        {
-            get { return global::PokemonGo.RocketAPI.GeneratedCode.PayloadsReflection.Descriptor.MessageTypes[2]; }
-        }
-
-        public long NextCollectTimestampMs
-        {
-            get { return nextCollectTimestampMs_; }
-            set { nextCollectTimestampMs_ = value; }
-        }
-
-        public long NextDefenderBonusCollectTimestampMs
-        {
-            get { return nextDefenderBonusCollectTimestampMs_; }
-            set { nextDefenderBonusCollectTimestampMs_ = value; }
-        }
-
-        pbr::MessageDescriptor pb::IMessage.Descriptor
-        {
-            get { return Descriptor; }
-        }
-
-        public DailyBonus Clone()
-        {
-            return new DailyBonus(this);
-        }
-
-        public bool Equals(DailyBonus other)
-        {
-            if (ReferenceEquals(other, null))
-            {
-                return false;
-            }
-            if (ReferenceEquals(other, this))
-            {
-                return true;
-            }
-            if (NextCollectTimestampMs != other.NextCollectTimestampMs) return false;
-            if (NextDefenderBonusCollectTimestampMs != other.NextDefenderBonusCollectTimestampMs) return false;
-            return true;
-        }
-
-        public void WriteTo(pb::CodedOutputStream output)
-        {
-            if (NextCollectTimestampMs != 0L)
-            {
-                output.WriteRawTag(8);
-                output.WriteInt64(NextCollectTimestampMs);
-            }
-            if (NextDefenderBonusCollectTimestampMs != 0L)
-            {
-                output.WriteRawTag(16);
-                output.WriteInt64(NextDefenderBonusCollectTimestampMs);
-            }
-        }
-
-        public int CalculateSize()
-        {
-            var size = 0;
-            if (NextCollectTimestampMs != 0L)
-            {
-                size += 1 + pb::CodedOutputStream.ComputeInt64Size(NextCollectTimestampMs);
-            }
-            if (NextDefenderBonusCollectTimestampMs != 0L)
-            {
-                size += 1 + pb::CodedOutputStream.ComputeInt64Size(NextDefenderBonusCollectTimestampMs);
-            }
-            return size;
-        }
-
-        public void MergeFrom(DailyBonus other)
-        {
-            if (other == null)
-            {
-                return;
-            }
-            if (other.NextCollectTimestampMs != 0L)
-            {
-                NextCollectTimestampMs = other.NextCollectTimestampMs;
-            }
-            if (other.NextDefenderBonusCollectTimestampMs != 0L)
-            {
-                NextDefenderBonusCollectTimestampMs = other.NextDefenderBonusCollectTimestampMs;
-            }
-        }
-
-        public void MergeFrom(pb::CodedInputStream input)
-        {
-            uint tag;
-            while ((tag = input.ReadTag()) != 0)
-            {
-                switch (tag)
-                {
-                    default:
-                        input.SkipLastField();
-                        break;
-                    case 8:
-                        {
-                            NextCollectTimestampMs = input.ReadInt64();
-                            break;
-                        }
-                    case 16:
-                        {
-                            NextDefenderBonusCollectTimestampMs = input.ReadInt64();
-                            break;
-                        }
-                }
-            }
-        }
-
-        public override bool Equals(object other)
-        {
-            return Equals(other as DailyBonus);
-        }
-
-        public override int GetHashCode()
-        {
-            var hash = 1;
-            if (NextCollectTimestampMs != 0L) hash ^= NextCollectTimestampMs.GetHashCode();
-            if (NextDefenderBonusCollectTimestampMs != 0L) hash ^= NextDefenderBonusCollectTimestampMs.GetHashCode();
-            return hash;
-        }
-
-        partial void OnConstruction();
-
-        public override string ToString()
-        {
-            return pb::JsonFormatter.ToDiagnosticString(this);
-        }
-    }
-
-    [global::System.Diagnostics.DebuggerNonUserCodeAttribute()]
-    public sealed partial class Currency : pb::IMessage<Currency>
-    {
-        /// <summary>Field number for the "type" field.</summary>
-        public const int TypeFieldNumber = 1;
-
-        /// <summary>Field number for the "amount" field.</summary>
-        public const int AmountFieldNumber = 2;
-
-        private static readonly pb::MessageParser<Currency> _parser =
-            new pb::MessageParser<Currency>(() => new Currency());
-
-        private int amount_;
-        private string type_ = "";
-
-        public Currency()
-        {
-            OnConstruction();
-        }
-
-        public Currency(Currency other) : this()
-        {
-            type_ = other.type_;
-            amount_ = other.amount_;
-        }
-
-        public static pb::MessageParser<Currency> Parser
-        {
-            get { return _parser; }
-        }
-
-        public static pbr::MessageDescriptor Descriptor
-        {
-            get { return global::PokemonGo.RocketAPI.GeneratedCode.PayloadsReflection.Descriptor.MessageTypes[3]; }
-        }
-
-        public string Type
-        {
-            get { return type_; }
-            set { type_ = pb::ProtoPreconditions.CheckNotNull(value, "value"); }
-        }
-
-        public int Amount
-        {
-            get { return amount_; }
-            set { amount_ = value; }
-        }
-
-        pbr::MessageDescriptor pb::IMessage.Descriptor
-        {
-            get { return Descriptor; }
-        }
-
-        public Currency Clone()
-        {
-            return new Currency(this);
-        }
-
-        public bool Equals(Currency other)
-        {
-            if (ReferenceEquals(other, null))
-            {
-                return false;
-            }
-            if (ReferenceEquals(other, this))
-            {
-                return true;
-            }
-            if (Type != other.Type) return false;
-            if (Amount != other.Amount) return false;
-            return true;
-        }
-
-        public void WriteTo(pb::CodedOutputStream output)
-        {
-            if (Type.Length != 0)
-            {
-                output.WriteRawTag(10);
-                output.WriteString(Type);
-            }
-            if (Amount != 0)
-            {
-                output.WriteRawTag(16);
-                output.WriteInt32(Amount);
-            }
-        }
-
-        public int CalculateSize()
-        {
-            var size = 0;
-            if (Type.Length != 0)
-            {
-                size += 1 + pb::CodedOutputStream.ComputeStringSize(Type);
-            }
-            if (Amount != 0)
-            {
-                size += 1 + pb::CodedOutputStream.ComputeInt32Size(Amount);
-            }
-            return size;
-        }
-
-        public void MergeFrom(Currency other)
-        {
-            if (other == null)
-            {
-                return;
-            }
-            if (other.Type.Length != 0)
-            {
-                Type = other.Type;
-            }
-            if (other.Amount != 0)
-            {
-                Amount = other.Amount;
-            }
-        }
-
-        public void MergeFrom(pb::CodedInputStream input)
-        {
-            uint tag;
-            while ((tag = input.ReadTag()) != 0)
-            {
-                switch (tag)
-                {
-                    default:
-                        input.SkipLastField();
-                        break;
-                    case 10:
-                        {
-                            Type = input.ReadString();
-                            break;
-                        }
-                    case 16:
-                        {
-                            Amount = input.ReadInt32();
-                            break;
-                        }
-                }
-            }
-        }
-
-        public override bool Equals(object other)
-        {
-            return Equals(other as Currency);
-        }
-
-        public override int GetHashCode()
-        {
-            var hash = 1;
-            if (Type.Length != 0) hash ^= Type.GetHashCode();
-            if (Amount != 0) hash ^= Amount.GetHashCode();
-            return hash;
-        }
-
-        partial void OnConstruction();
-
-        public override string ToString()
-        {
-            return pb::JsonFormatter.ToDiagnosticString(this);
-        }
-    }
-
-    [global::System.Diagnostics.DebuggerNonUserCodeAttribute()]
-    public sealed partial class AvatarDetails : pb::IMessage<AvatarDetails>
-    {
-        /// <summary>Field number for the "unknown2" field.</summary>
-        public const int Unknown2FieldNumber = 2;
-
-        /// <summary>Field number for the "unknown3" field.</summary>
-        public const int Unknown3FieldNumber = 3;
-
-        /// <summary>Field number for the "unknown9" field.</summary>
-        public const int Unknown9FieldNumber = 9;
-
-        /// <summary>Field number for the "unknown10" field.</summary>
-        public const int Unknown10FieldNumber = 10;
-
-        private static readonly pb::MessageParser<AvatarDetails> _parser =
-            new pb::MessageParser<AvatarDetails>(() => new AvatarDetails());
-
-        private int unknown10_;
-        private int unknown2_;
-        private int unknown3_;
-        private int unknown9_;
-
-        public AvatarDetails()
-        {
-            OnConstruction();
-        }
-
-        public AvatarDetails(AvatarDetails other) : this()
-        {
-            unknown2_ = other.unknown2_;
-            unknown3_ = other.unknown3_;
-            unknown9_ = other.unknown9_;
-            unknown10_ = other.unknown10_;
-        }
-
-        public static pb::MessageParser<AvatarDetails> Parser
-        {
-            get { return _parser; }
-        }
-
-        public static pbr::MessageDescriptor Descriptor
-        {
-            get { return global::PokemonGo.RocketAPI.GeneratedCode.PayloadsReflection.Descriptor.MessageTypes[4]; }
-        }
-
-        public int Unknown2
-        {
-            get { return unknown2_; }
-            set { unknown2_ = value; }
-        }
-
-        public int Unknown3
-        {
-            get { return unknown3_; }
-            set { unknown3_ = value; }
-        }
-
-        public int Unknown9
-        {
-            get { return unknown9_; }
-            set { unknown9_ = value; }
-        }
-
-        public int Unknown10
-        {
-            get { return unknown10_; }
-            set { unknown10_ = value; }
-        }
-
-        pbr::MessageDescriptor pb::IMessage.Descriptor
-        {
-            get { return Descriptor; }
-        }
-
-        public AvatarDetails Clone()
-        {
-            return new AvatarDetails(this);
-        }
-
-        public bool Equals(AvatarDetails other)
-        {
-            if (ReferenceEquals(other, null))
-            {
-                return false;
-            }
-            if (ReferenceEquals(other, this))
-            {
-                return true;
-            }
-            if (Unknown2 != other.Unknown2) return false;
-            if (Unknown3 != other.Unknown3) return false;
-            if (Unknown9 != other.Unknown9) return false;
-            if (Unknown10 != other.Unknown10) return false;
-            return true;
-        }
-
-        public void WriteTo(pb::CodedOutputStream output)
-        {
-            if (Unknown2 != 0)
-            {
-                output.WriteRawTag(16);
-                output.WriteInt32(Unknown2);
-            }
-            if (Unknown3 != 0)
-            {
-                output.WriteRawTag(24);
-                output.WriteInt32(Unknown3);
-            }
-            if (Unknown9 != 0)
-            {
-                output.WriteRawTag(72);
-                output.WriteInt32(Unknown9);
-            }
-            if (Unknown10 != 0)
-            {
-                output.WriteRawTag(80);
-                output.WriteInt32(Unknown10);
-            }
-        }
-
-        public int CalculateSize()
-        {
-            var size = 0;
-            if (Unknown2 != 0)
-            {
-                size += 1 + pb::CodedOutputStream.ComputeInt32Size(Unknown2);
-            }
-            if (Unknown3 != 0)
-            {
-                size += 1 + pb::CodedOutputStream.ComputeInt32Size(Unknown3);
-            }
-            if (Unknown9 != 0)
-            {
-                size += 1 + pb::CodedOutputStream.ComputeInt32Size(Unknown9);
-            }
-            if (Unknown10 != 0)
-            {
-                size += 1 + pb::CodedOutputStream.ComputeInt32Size(Unknown10);
-            }
-            return size;
-        }
-
-        public void MergeFrom(AvatarDetails other)
-        {
-            if (other == null)
-            {
-                return;
-            }
-            if (other.Unknown2 != 0)
-            {
-                Unknown2 = other.Unknown2;
-            }
-            if (other.Unknown3 != 0)
-            {
-                Unknown3 = other.Unknown3;
-            }
-            if (other.Unknown9 != 0)
-            {
-                Unknown9 = other.Unknown9;
-            }
-            if (other.Unknown10 != 0)
-            {
-                Unknown10 = other.Unknown10;
-            }
-        }
-
-        public void MergeFrom(pb::CodedInputStream input)
-        {
-            uint tag;
-            while ((tag = input.ReadTag()) != 0)
-            {
-                switch (tag)
-                {
-                    default:
-                        input.SkipLastField();
-                        break;
-                    case 16:
-                        {
-                            Unknown2 = input.ReadInt32();
-                            break;
-                        }
-                    case 24:
-                        {
-                            Unknown3 = input.ReadInt32();
-                            break;
-                        }
-                    case 72:
-                        {
-                            Unknown9 = input.ReadInt32();
-                            break;
-                        }
-                    case 80:
-                        {
-                            Unknown10 = input.ReadInt32();
-                            break;
-                        }
-                }
-            }
-        }
-
-        public override bool Equals(object other)
-        {
-            return Equals(other as AvatarDetails);
-        }
-
-        public override int GetHashCode()
-        {
-            var hash = 1;
-            if (Unknown2 != 0) hash ^= Unknown2.GetHashCode();
-            if (Unknown3 != 0) hash ^= Unknown3.GetHashCode();
-            if (Unknown9 != 0) hash ^= Unknown9.GetHashCode();
-            if (Unknown10 != 0) hash ^= Unknown10.GetHashCode();
-            return hash;
-        }
-
-        partial void OnConstruction();
-
-        public override string ToString()
-        {
-            return pb::JsonFormatter.ToDiagnosticString(this);
-        }
-    }
-
-    [global::System.Diagnostics.DebuggerNonUserCodeAttribute()]
-    public sealed partial class DownloadSettingsRequest : pb::IMessage<DownloadSettingsRequest>
-    {
-        /// <summary>Field number for the "hash" field.</summary>
-        public const int HashFieldNumber = 1;
-
-        private static readonly pb::MessageParser<DownloadSettingsRequest> _parser =
-            new pb::MessageParser<DownloadSettingsRequest>(() => new DownloadSettingsRequest());
-
-        private string hash_ = "";
-
-        public DownloadSettingsRequest()
-        {
-            OnConstruction();
-        }
-
-        public DownloadSettingsRequest(DownloadSettingsRequest other) : this()
-        {
-            hash_ = other.hash_;
-        }
-
-        public static pb::MessageParser<DownloadSettingsRequest> Parser
-        {
-            get { return _parser; }
-        }
-
-        public static pbr::MessageDescriptor Descriptor
-        {
-            get { return global::PokemonGo.RocketAPI.GeneratedCode.PayloadsReflection.Descriptor.MessageTypes[5]; }
-        }
-
-        public string Hash
-        {
-            get { return hash_; }
-            set { hash_ = pb::ProtoPreconditions.CheckNotNull(value, "value"); }
-        }
-
-        pbr::MessageDescriptor pb::IMessage.Descriptor
-        {
-            get { return Descriptor; }
-        }
-
-        public DownloadSettingsRequest Clone()
-        {
-            return new DownloadSettingsRequest(this);
-        }
-
-        public bool Equals(DownloadSettingsRequest other)
-        {
-            if (ReferenceEquals(other, null))
-            {
-                return false;
-            }
-            if (ReferenceEquals(other, this))
-            {
-                return true;
-            }
-            if (Hash != other.Hash) return false;
-            return true;
-        }
-
-        public void WriteTo(pb::CodedOutputStream output)
-        {
-            if (Hash.Length != 0)
-            {
-                output.WriteRawTag(10);
-                output.WriteString(Hash);
-            }
-        }
-
-        public int CalculateSize()
-        {
-            var size = 0;
-            if (Hash.Length != 0)
-            {
-                size += 1 + pb::CodedOutputStream.ComputeStringSize(Hash);
-            }
-            return size;
-        }
-
-        public void MergeFrom(DownloadSettingsRequest other)
-        {
-            if (other == null)
-            {
-                return;
-            }
-            if (other.Hash.Length != 0)
-            {
-                Hash = other.Hash;
-            }
-        }
-
-        public void MergeFrom(pb::CodedInputStream input)
-        {
-            uint tag;
-            while ((tag = input.ReadTag()) != 0)
-            {
-                switch (tag)
-                {
-                    default:
-                        input.SkipLastField();
-                        break;
-                    case 10:
-                        {
-                            Hash = input.ReadString();
-                            break;
-                        }
-                }
-            }
-        }
-
-        public override bool Equals(object other)
-        {
-            return Equals(other as DownloadSettingsRequest);
-        }
-
-        public override int GetHashCode()
-        {
-            var hash = 1;
-            if (Hash.Length != 0) hash ^= Hash.GetHashCode();
-            return hash;
-        }
-
-        partial void OnConstruction();
-
-        public override string ToString()
-        {
-            return pb::JsonFormatter.ToDiagnosticString(this);
-        }
-    }
-
-    [global::System.Diagnostics.DebuggerNonUserCodeAttribute()]
-    public sealed partial class GetInventoryResponse : pb::IMessage<GetInventoryResponse>
-    {
-        /// <summary>Field number for the "success" field.</summary>
-        public const int SuccessFieldNumber = 1;
-
-        /// <summary>Field number for the "inventory_delta" field.</summary>
-        public const int InventoryDeltaFieldNumber = 2;
-
-        private static readonly pb::MessageParser<GetInventoryResponse> _parser =
-            new pb::MessageParser<GetInventoryResponse>(() => new GetInventoryResponse());
-
-        private global::PokemonGo.RocketAPI.GeneratedCode.InventoryDelta inventoryDelta_;
-        private bool success_;
-
-        public GetInventoryResponse()
-        {
-            OnConstruction();
-        }
-
-        public GetInventoryResponse(GetInventoryResponse other) : this()
-        {
-            success_ = other.success_;
-            InventoryDelta = other.inventoryDelta_ != null ? other.InventoryDelta.Clone() : null;
-        }
-
-        public static pb::MessageParser<GetInventoryResponse> Parser
-        {
-            get { return _parser; }
-        }
-
-        public static pbr::MessageDescriptor Descriptor
-        {
-            get { return global::PokemonGo.RocketAPI.GeneratedCode.PayloadsReflection.Descriptor.MessageTypes[6]; }
-        }
-
-        public bool Success
-        {
-            get { return success_; }
-            set { success_ = value; }
-        }
-
-        public global::PokemonGo.RocketAPI.GeneratedCode.InventoryDelta InventoryDelta
-        {
-            get { return inventoryDelta_; }
-            set { inventoryDelta_ = value; }
-        }
-
-        pbr::MessageDescriptor pb::IMessage.Descriptor
-        {
-            get { return Descriptor; }
-        }
-
-        public GetInventoryResponse Clone()
-        {
-            return new GetInventoryResponse(this);
-        }
-
-        public bool Equals(GetInventoryResponse other)
-        {
-            if (ReferenceEquals(other, null))
-            {
-                return false;
-            }
-            if (ReferenceEquals(other, this))
-            {
-                return true;
-            }
-            if (Success != other.Success) return false;
-            if (!Equals(InventoryDelta, other.InventoryDelta)) return false;
-            return true;
-        }
-
-        public void WriteTo(pb::CodedOutputStream output)
-        {
-            if (Success != false)
-            {
-                output.WriteRawTag(8);
-                output.WriteBool(Success);
-            }
-            if (inventoryDelta_ != null)
-            {
-                output.WriteRawTag(18);
-                output.WriteMessage(InventoryDelta);
-            }
-        }
-
-        public int CalculateSize()
-        {
-            var size = 0;
-            if (Success != false)
-            {
-                size += 1 + 1;
-            }
-            if (inventoryDelta_ != null)
-            {
-                size += 1 + pb::CodedOutputStream.ComputeMessageSize(InventoryDelta);
-            }
-            return size;
-        }
-
-        public void MergeFrom(GetInventoryResponse other)
-        {
-            if (other == null)
-            {
-                return;
-            }
-            if (other.Success != false)
-            {
-                Success = other.Success;
-            }
-            if (other.inventoryDelta_ != null)
-            {
-                if (inventoryDelta_ == null)
-                {
-                    inventoryDelta_ = new global::PokemonGo.RocketAPI.GeneratedCode.InventoryDelta();
-                }
-                InventoryDelta.MergeFrom(other.InventoryDelta);
-            }
-        }
-
-        public void MergeFrom(pb::CodedInputStream input)
-        {
-            uint tag;
-            while ((tag = input.ReadTag()) != 0)
-            {
-                switch (tag)
-                {
-                    default:
-                        input.SkipLastField();
-                        break;
-                    case 8:
-                        {
-                            Success = input.ReadBool();
-                            break;
-                        }
-                    case 18:
-                        {
-                            if (inventoryDelta_ == null)
-                            {
-                                inventoryDelta_ = new global::PokemonGo.RocketAPI.GeneratedCode.InventoryDelta();
-                            }
-                            input.ReadMessage(inventoryDelta_);
-                            break;
-                        }
-                }
-            }
-        }
-
-        public override bool Equals(object other)
-        {
-            return Equals(other as GetInventoryResponse);
-        }
-
-        public override int GetHashCode()
-        {
-            var hash = 1;
-            if (Success != false) hash ^= Success.GetHashCode();
-            if (inventoryDelta_ != null) hash ^= InventoryDelta.GetHashCode();
-            return hash;
-        }
-
-        partial void OnConstruction();
-
-        public override string ToString()
-        {
-            return pb::JsonFormatter.ToDiagnosticString(this);
-        }
-    }
-
-    [global::System.Diagnostics.DebuggerNonUserCodeAttribute()]
-    public sealed partial class InventoryDelta : pb::IMessage<InventoryDelta>
-    {
-        /// <summary>Field number for the "original_timestamp_ms" field.</summary>
-        public const int OriginalTimestampMsFieldNumber = 1;
-
-        /// <summary>Field number for the "new_timestamp_ms" field.</summary>
-        public const int NewTimestampMsFieldNumber = 2;
-
-        /// <summary>Field number for the "inventory_items" field.</summary>
-        public const int InventoryItemsFieldNumber = 3;
-
-        private static readonly pb::MessageParser<InventoryDelta> _parser =
-            new pb::MessageParser<InventoryDelta>(() => new InventoryDelta());
-
-        private static readonly pb::FieldCodec<global::PokemonGo.RocketAPI.GeneratedCode.InventoryItem>
-            _repeated_inventoryItems_codec
-                = pb::FieldCodec.ForMessage(26, global::PokemonGo.RocketAPI.GeneratedCode.InventoryItem.Parser);
-
-        private readonly pbc::RepeatedField<global::PokemonGo.RocketAPI.GeneratedCode.InventoryItem> inventoryItems_ =
-            new pbc::RepeatedField<global::PokemonGo.RocketAPI.GeneratedCode.InventoryItem>();
-
-        private long newTimestampMs_;
-        private long originalTimestampMs_;
-
-        public InventoryDelta()
-        {
-            OnConstruction();
-        }
-
-        public InventoryDelta(InventoryDelta other) : this()
-        {
-            originalTimestampMs_ = other.originalTimestampMs_;
-            newTimestampMs_ = other.newTimestampMs_;
-            inventoryItems_ = other.inventoryItems_.Clone();
-        }
-
-        public static pb::MessageParser<InventoryDelta> Parser
-        {
-            get { return _parser; }
-        }
-
-        public static pbr::MessageDescriptor Descriptor
-        {
-            get { return global::PokemonGo.RocketAPI.GeneratedCode.PayloadsReflection.Descriptor.MessageTypes[7]; }
-        }
-
-        public long OriginalTimestampMs
-        {
-            get { return originalTimestampMs_; }
-            set { originalTimestampMs_ = value; }
-        }
-
-        public long NewTimestampMs
-        {
-            get { return newTimestampMs_; }
-            set { newTimestampMs_ = value; }
-        }
-
-        public pbc::RepeatedField<global::PokemonGo.RocketAPI.GeneratedCode.InventoryItem> InventoryItems
-        {
-            get { return inventoryItems_; }
-        }
-
-        pbr::MessageDescriptor pb::IMessage.Descriptor
-        {
-            get { return Descriptor; }
-        }
-
-        public InventoryDelta Clone()
-        {
-            return new InventoryDelta(this);
-        }
-
-        public bool Equals(InventoryDelta other)
-        {
-            if (ReferenceEquals(other, null))
-            {
-                return false;
-            }
-            if (ReferenceEquals(other, this))
-            {
-                return true;
-            }
-            if (OriginalTimestampMs != other.OriginalTimestampMs) return false;
-            if (NewTimestampMs != other.NewTimestampMs) return false;
-            if (!inventoryItems_.Equals(other.inventoryItems_)) return false;
-            return true;
-        }
-
-        public void WriteTo(pb::CodedOutputStream output)
-        {
-            if (OriginalTimestampMs != 0L)
-            {
-                output.WriteRawTag(8);
-                output.WriteInt64(OriginalTimestampMs);
-            }
-            if (NewTimestampMs != 0L)
-            {
-                output.WriteRawTag(16);
-                output.WriteInt64(NewTimestampMs);
-            }
-            inventoryItems_.WriteTo(output, _repeated_inventoryItems_codec);
-        }
-
-        public int CalculateSize()
-        {
-            var size = 0;
-            if (OriginalTimestampMs != 0L)
-            {
-                size += 1 + pb::CodedOutputStream.ComputeInt64Size(OriginalTimestampMs);
-            }
-            if (NewTimestampMs != 0L)
-            {
-                size += 1 + pb::CodedOutputStream.ComputeInt64Size(NewTimestampMs);
-            }
-            size += inventoryItems_.CalculateSize(_repeated_inventoryItems_codec);
-            return size;
-        }
-
-        public void MergeFrom(InventoryDelta other)
-        {
-            if (other == null)
-            {
-                return;
-            }
-            if (other.OriginalTimestampMs != 0L)
-            {
-                OriginalTimestampMs = other.OriginalTimestampMs;
-            }
-            if (other.NewTimestampMs != 0L)
-            {
-                NewTimestampMs = other.NewTimestampMs;
-            }
-            inventoryItems_.Add(other.inventoryItems_);
-        }
-
-        public void MergeFrom(pb::CodedInputStream input)
-        {
-            uint tag;
-            while ((tag = input.ReadTag()) != 0)
-            {
-                switch (tag)
-                {
-                    default:
-                        input.SkipLastField();
-                        break;
-                    case 8:
-                        {
-                            OriginalTimestampMs = input.ReadInt64();
-                            break;
-                        }
-                    case 16:
-                        {
-                            NewTimestampMs = input.ReadInt64();
-                            break;
-                        }
-                    case 26:
-                        {
-                            inventoryItems_.AddEntriesFrom(input, _repeated_inventoryItems_codec);
-                            break;
-                        }
-                }
-            }
-        }
-
-        public override bool Equals(object other)
-        {
-            return Equals(other as InventoryDelta);
-        }
-
-        public override int GetHashCode()
-        {
-            var hash = 1;
-            if (OriginalTimestampMs != 0L) hash ^= OriginalTimestampMs.GetHashCode();
-            if (NewTimestampMs != 0L) hash ^= NewTimestampMs.GetHashCode();
-            hash ^= inventoryItems_.GetHashCode();
-            return hash;
-        }
-
-        partial void OnConstruction();
-
-        public override string ToString()
-        {
-            return pb::JsonFormatter.ToDiagnosticString(this);
-        }
-    }
-
-    [global::System.Diagnostics.DebuggerNonUserCodeAttribute()]
-    public sealed partial class InventoryItem : pb::IMessage<InventoryItem>
-    {
-        /// <summary>Field number for the "modified_timestamp_ms" field.</summary>
-        public const int ModifiedTimestampMsFieldNumber = 1;
-
-        /// <summary>Field number for the "deleted_item_key" field.</summary>
-        public const int DeletedItemKeyFieldNumber = 2;
-
-        /// <summary>Field number for the "inventory_item_data" field.</summary>
-        public const int InventoryItemDataFieldNumber = 3;
-
-        private static readonly pb::MessageParser<InventoryItem> _parser =
-            new pb::MessageParser<InventoryItem>(() => new InventoryItem());
-
-        private long deletedItemKey_;
-        private global::PokemonGo.RocketAPI.GeneratedCode.InventoryItemData inventoryItemData_;
-        private long modifiedTimestampMs_;
-
-        public InventoryItem()
-        {
-            OnConstruction();
-        }
-
-        public InventoryItem(InventoryItem other) : this()
-        {
-            modifiedTimestampMs_ = other.modifiedTimestampMs_;
-            deletedItemKey_ = other.deletedItemKey_;
-            InventoryItemData = other.inventoryItemData_ != null ? other.InventoryItemData.Clone() : null;
-        }
-
-        public static pb::MessageParser<InventoryItem> Parser
-        {
-            get { return _parser; }
-        }
-
-        public static pbr::MessageDescriptor Descriptor
-        {
-            get { return global::PokemonGo.RocketAPI.GeneratedCode.PayloadsReflection.Descriptor.MessageTypes[8]; }
-        }
-
-        public long ModifiedTimestampMs
-        {
-            get { return modifiedTimestampMs_; }
-            set { modifiedTimestampMs_ = value; }
-        }
-
-        public long DeletedItemKey
-        {
-            get { return deletedItemKey_; }
-            set { deletedItemKey_ = value; }
-        }
-
-        public global::PokemonGo.RocketAPI.GeneratedCode.InventoryItemData InventoryItemData
-        {
-            get { return inventoryItemData_; }
-            set { inventoryItemData_ = value; }
-        }
-
-        pbr::MessageDescriptor pb::IMessage.Descriptor
-        {
-            get { return Descriptor; }
-        }
-
-        public InventoryItem Clone()
-        {
-            return new InventoryItem(this);
-        }
-
-        public bool Equals(InventoryItem other)
-        {
-            if (ReferenceEquals(other, null))
-            {
-                return false;
-            }
-            if (ReferenceEquals(other, this))
-            {
-                return true;
-            }
-            if (ModifiedTimestampMs != other.ModifiedTimestampMs) return false;
-            if (DeletedItemKey != other.DeletedItemKey) return false;
-            if (!Equals(InventoryItemData, other.InventoryItemData)) return false;
-            return true;
-        }
-
-        public void WriteTo(pb::CodedOutputStream output)
-        {
-            if (ModifiedTimestampMs != 0L)
-            {
-                output.WriteRawTag(8);
-                output.WriteInt64(ModifiedTimestampMs);
-            }
-            if (DeletedItemKey != 0L)
-            {
-                output.WriteRawTag(16);
-                output.WriteInt64(DeletedItemKey);
-            }
-            if (inventoryItemData_ != null)
-            {
-                output.WriteRawTag(26);
-                output.WriteMessage(InventoryItemData);
-            }
-        }
-
-        public int CalculateSize()
-        {
-            var size = 0;
-            if (ModifiedTimestampMs != 0L)
-            {
-                size += 1 + pb::CodedOutputStream.ComputeInt64Size(ModifiedTimestampMs);
-            }
-            if (DeletedItemKey != 0L)
-            {
-                size += 1 + pb::CodedOutputStream.ComputeInt64Size(DeletedItemKey);
-            }
-            if (inventoryItemData_ != null)
-            {
-                size += 1 + pb::CodedOutputStream.ComputeMessageSize(InventoryItemData);
-            }
-            return size;
-        }
-
-        public void MergeFrom(InventoryItem other)
-        {
-            if (other == null)
-            {
-                return;
-            }
-            if (other.ModifiedTimestampMs != 0L)
-            {
-                ModifiedTimestampMs = other.ModifiedTimestampMs;
-            }
-            if (other.DeletedItemKey != 0L)
-            {
-                DeletedItemKey = other.DeletedItemKey;
-            }
-            if (other.inventoryItemData_ != null)
-            {
-                if (inventoryItemData_ == null)
-                {
-                    inventoryItemData_ = new global::PokemonGo.RocketAPI.GeneratedCode.InventoryItemData();
-                }
-                InventoryItemData.MergeFrom(other.InventoryItemData);
-            }
-        }
-
-        public void MergeFrom(pb::CodedInputStream input)
-        {
-            uint tag;
-            while ((tag = input.ReadTag()) != 0)
-            {
-                switch (tag)
-                {
-                    default:
-                        input.SkipLastField();
-                        break;
-                    case 8:
-                        {
-                            ModifiedTimestampMs = input.ReadInt64();
-                            break;
-                        }
-                    case 16:
-                        {
-                            DeletedItemKey = input.ReadInt64();
-                            break;
-                        }
-                    case 26:
-                        {
-                            if (inventoryItemData_ == null)
-                            {
-                                inventoryItemData_ = new global::PokemonGo.RocketAPI.GeneratedCode.InventoryItemData();
-                            }
-                            input.ReadMessage(inventoryItemData_);
-                            break;
-                        }
-                }
-            }
-        }
-
-        public override bool Equals(object other)
-        {
-            return Equals(other as InventoryItem);
-        }
-
-        public override int GetHashCode()
-        {
-            var hash = 1;
-            if (ModifiedTimestampMs != 0L) hash ^= ModifiedTimestampMs.GetHashCode();
-            if (DeletedItemKey != 0L) hash ^= DeletedItemKey.GetHashCode();
-            if (inventoryItemData_ != null) hash ^= InventoryItemData.GetHashCode();
-            return hash;
-        }
-
-        partial void OnConstruction();
-
-        public override string ToString()
-        {
-            return pb::JsonFormatter.ToDiagnosticString(this);
-        }
-    }
-
-    [global::System.Diagnostics.DebuggerNonUserCodeAttribute()]
-    public sealed partial class InventoryItemData : pb::IMessage<InventoryItemData>
-    {
-        /// <summary>Field number for the "pokemon" field.</summary>
-        public const int PokemonFieldNumber = 1;
-
-        /// <summary>Field number for the "item" field.</summary>
-        public const int ItemFieldNumber = 2;
-
-        /// <summary>Field number for the "pokedex_entry" field.</summary>
-        public const int PokedexEntryFieldNumber = 3;
-
-        /// <summary>Field number for the "player_stats" field.</summary>
-        public const int PlayerStatsFieldNumber = 4;
-
-        /// <summary>Field number for the "player_currency" field.</summary>
-        public const int PlayerCurrencyFieldNumber = 5;
-
-        /// <summary>Field number for the "player_camera" field.</summary>
-        public const int PlayerCameraFieldNumber = 6;
-
-        /// <summary>Field number for the "inventory_upgrades" field.</summary>
-        public const int InventoryUpgradesFieldNumber = 7;
-
-        /// <summary>Field number for the "applied_items" field.</summary>
-        public const int AppliedItemsFieldNumber = 8;
-
-        /// <summary>Field number for the "egg_incubators" field.</summary>
-        public const int EggIncubatorsFieldNumber = 9;
-
-        /// <summary>Field number for the "pokemon_family" field.</summary>
-        public const int PokemonFamilyFieldNumber = 10;
-
-        private static readonly pb::MessageParser<InventoryItemData> _parser =
-            new pb::MessageParser<InventoryItemData>(() => new InventoryItemData());
-
-        private global::PokemonGo.RocketAPI.GeneratedCode.AppliedItems appliedItems_;
-        private global::PokemonGo.RocketAPI.GeneratedCode.EggIncubators eggIncubators_;
-        private global::PokemonGo.RocketAPI.GeneratedCode.InventoryUpgrades inventoryUpgrades_;
-        private global::PokemonGo.RocketAPI.GeneratedCode.Item item_;
-        private global::PokemonGo.RocketAPI.GeneratedCode.PlayerCamera playerCamera_;
-        private global::PokemonGo.RocketAPI.GeneratedCode.PlayerCurrency playerCurrency_;
-        private global::PokemonGo.RocketAPI.GeneratedCode.PlayerStats playerStats_;
-        private global::PokemonGo.RocketAPI.GeneratedCode.PokedexEntry pokedexEntry_;
-        private global::PokemonGo.RocketAPI.GeneratedCode.PokemonData pokemon_;
-        private global::PokemonGo.RocketAPI.GeneratedCode.PokemonFamily pokemonFamily_;
-
-        public InventoryItemData()
-        {
-            OnConstruction();
-        }
-
-        public InventoryItemData(InventoryItemData other) : this()
-        {
-            Pokemon = other.pokemon_ != null ? other.Pokemon.Clone() : null;
-            Item = other.item_ != null ? other.Item.Clone() : null;
-            PokedexEntry = other.pokedexEntry_ != null ? other.PokedexEntry.Clone() : null;
-            PlayerStats = other.playerStats_ != null ? other.PlayerStats.Clone() : null;
-            PlayerCurrency = other.playerCurrency_ != null ? other.PlayerCurrency.Clone() : null;
-            PlayerCamera = other.playerCamera_ != null ? other.PlayerCamera.Clone() : null;
-            InventoryUpgrades = other.inventoryUpgrades_ != null ? other.InventoryUpgrades.Clone() : null;
-            AppliedItems = other.appliedItems_ != null ? other.AppliedItems.Clone() : null;
-            EggIncubators = other.eggIncubators_ != null ? other.EggIncubators.Clone() : null;
-            PokemonFamily = other.pokemonFamily_ != null ? other.PokemonFamily.Clone() : null;
-        }
-
-        public static pb::MessageParser<InventoryItemData> Parser
-        {
-            get { return _parser; }
-        }
-
-        public static pbr::MessageDescriptor Descriptor
-        {
-            get { return global::PokemonGo.RocketAPI.GeneratedCode.PayloadsReflection.Descriptor.MessageTypes[9]; }
-        }
-
-        public global::PokemonGo.RocketAPI.GeneratedCode.PokemonData Pokemon
-        {
-            get { return pokemon_; }
-            set { pokemon_ = value; }
-        }
-
-        public global::PokemonGo.RocketAPI.GeneratedCode.Item Item
-        {
-            get { return item_; }
-            set { item_ = value; }
-        }
-
-        public global::PokemonGo.RocketAPI.GeneratedCode.PokedexEntry PokedexEntry
-        {
-            get { return pokedexEntry_; }
-            set { pokedexEntry_ = value; }
-        }
-
-        public global::PokemonGo.RocketAPI.GeneratedCode.PlayerStats PlayerStats
-        {
-            get { return playerStats_; }
-            set { playerStats_ = value; }
-        }
-
-        public global::PokemonGo.RocketAPI.GeneratedCode.PlayerCurrency PlayerCurrency
-        {
-            get { return playerCurrency_; }
-            set { playerCurrency_ = value; }
-        }
-
-        public global::PokemonGo.RocketAPI.GeneratedCode.PlayerCamera PlayerCamera
-        {
-            get { return playerCamera_; }
-            set { playerCamera_ = value; }
-        }
-
-        public global::PokemonGo.RocketAPI.GeneratedCode.InventoryUpgrades InventoryUpgrades
-        {
-            get { return inventoryUpgrades_; }
-            set { inventoryUpgrades_ = value; }
-        }
-
-        public global::PokemonGo.RocketAPI.GeneratedCode.AppliedItems AppliedItems
-        {
-            get { return appliedItems_; }
-            set { appliedItems_ = value; }
-        }
-
-        public global::PokemonGo.RocketAPI.GeneratedCode.EggIncubators EggIncubators
-        {
-            get { return eggIncubators_; }
-            set { eggIncubators_ = value; }
-        }
-
-        public global::PokemonGo.RocketAPI.GeneratedCode.PokemonFamily PokemonFamily
-        {
-            get { return pokemonFamily_; }
-            set { pokemonFamily_ = value; }
-        }
-
-        pbr::MessageDescriptor pb::IMessage.Descriptor
-        {
-            get { return Descriptor; }
-        }
-
-        public InventoryItemData Clone()
-        {
-            return new InventoryItemData(this);
-        }
-
-        public bool Equals(InventoryItemData other)
-        {
-            if (ReferenceEquals(other, null))
-            {
-                return false;
-            }
-            if (ReferenceEquals(other, this))
-            {
-                return true;
-            }
-            if (!Equals(Pokemon, other.Pokemon)) return false;
-            if (!Equals(Item, other.Item)) return false;
-            if (!Equals(PokedexEntry, other.PokedexEntry)) return false;
-            if (!Equals(PlayerStats, other.PlayerStats)) return false;
-            if (!Equals(PlayerCurrency, other.PlayerCurrency)) return false;
-            if (!Equals(PlayerCamera, other.PlayerCamera)) return false;
-            if (!Equals(InventoryUpgrades, other.InventoryUpgrades)) return false;
-            if (!Equals(AppliedItems, other.AppliedItems)) return false;
-            if (!Equals(EggIncubators, other.EggIncubators)) return false;
-            if (!Equals(PokemonFamily, other.PokemonFamily)) return false;
-            return true;
-        }
-
-        public void WriteTo(pb::CodedOutputStream output)
-        {
-            if (pokemon_ != null)
-            {
-                output.WriteRawTag(10);
-                output.WriteMessage(Pokemon);
-            }
-            if (item_ != null)
-            {
-                output.WriteRawTag(18);
-                output.WriteMessage(Item);
-            }
-            if (pokedexEntry_ != null)
-            {
-                output.WriteRawTag(26);
-                output.WriteMessage(PokedexEntry);
-            }
-            if (playerStats_ != null)
-            {
-                output.WriteRawTag(34);
-                output.WriteMessage(PlayerStats);
-            }
-            if (playerCurrency_ != null)
-            {
-                output.WriteRawTag(42);
-                output.WriteMessage(PlayerCurrency);
-            }
-            if (playerCamera_ != null)
-            {
-                output.WriteRawTag(50);
-                output.WriteMessage(PlayerCamera);
-            }
-            if (inventoryUpgrades_ != null)
-            {
-                output.WriteRawTag(58);
-                output.WriteMessage(InventoryUpgrades);
-            }
-            if (appliedItems_ != null)
-            {
-                output.WriteRawTag(66);
-                output.WriteMessage(AppliedItems);
-            }
-            if (eggIncubators_ != null)
-            {
-                output.WriteRawTag(74);
-                output.WriteMessage(EggIncubators);
-            }
-            if (pokemonFamily_ != null)
-            {
-                output.WriteRawTag(82);
-                output.WriteMessage(PokemonFamily);
-            }
-        }
-
-        public int CalculateSize()
-        {
-            var size = 0;
-            if (pokemon_ != null)
-            {
-                size += 1 + pb::CodedOutputStream.ComputeMessageSize(Pokemon);
-            }
-            if (item_ != null)
-            {
-                size += 1 + pb::CodedOutputStream.ComputeMessageSize(Item);
-            }
-            if (pokedexEntry_ != null)
-            {
-                size += 1 + pb::CodedOutputStream.ComputeMessageSize(PokedexEntry);
-            }
-            if (playerStats_ != null)
-            {
-                size += 1 + pb::CodedOutputStream.ComputeMessageSize(PlayerStats);
-            }
-            if (playerCurrency_ != null)
-            {
-                size += 1 + pb::CodedOutputStream.ComputeMessageSize(PlayerCurrency);
-            }
-            if (playerCamera_ != null)
-            {
-                size += 1 + pb::CodedOutputStream.ComputeMessageSize(PlayerCamera);
-            }
-            if (inventoryUpgrades_ != null)
-            {
-                size += 1 + pb::CodedOutputStream.ComputeMessageSize(InventoryUpgrades);
-            }
-            if (appliedItems_ != null)
-            {
-                size += 1 + pb::CodedOutputStream.ComputeMessageSize(AppliedItems);
-            }
-            if (eggIncubators_ != null)
-            {
-                size += 1 + pb::CodedOutputStream.ComputeMessageSize(EggIncubators);
-            }
-            if (pokemonFamily_ != null)
-            {
-                size += 1 + pb::CodedOutputStream.ComputeMessageSize(PokemonFamily);
-            }
-            return size;
-        }
-
-        public void MergeFrom(InventoryItemData other)
-        {
-            if (other == null)
-            {
-                return;
-            }
-            if (other.pokemon_ != null)
-            {
-                if (pokemon_ == null)
-                {
-                    pokemon_ = new global::PokemonGo.RocketAPI.GeneratedCode.PokemonData();
-                }
-                Pokemon.MergeFrom(other.Pokemon);
-            }
-            if (other.item_ != null)
-            {
-                if (item_ == null)
-                {
-                    item_ = new global::PokemonGo.RocketAPI.GeneratedCode.Item();
-                }
-                Item.MergeFrom(other.Item);
-            }
-            if (other.pokedexEntry_ != null)
-            {
-                if (pokedexEntry_ == null)
-                {
-                    pokedexEntry_ = new global::PokemonGo.RocketAPI.GeneratedCode.PokedexEntry();
-                }
-                PokedexEntry.MergeFrom(other.PokedexEntry);
-            }
-            if (other.playerStats_ != null)
-            {
-                if (playerStats_ == null)
-                {
-                    playerStats_ = new global::PokemonGo.RocketAPI.GeneratedCode.PlayerStats();
-                }
-                PlayerStats.MergeFrom(other.PlayerStats);
-            }
-            if (other.playerCurrency_ != null)
-            {
-                if (playerCurrency_ == null)
-                {
-                    playerCurrency_ = new global::PokemonGo.RocketAPI.GeneratedCode.PlayerCurrency();
-                }
-                PlayerCurrency.MergeFrom(other.PlayerCurrency);
-            }
-            if (other.playerCamera_ != null)
-            {
-                if (playerCamera_ == null)
-                {
-                    playerCamera_ = new global::PokemonGo.RocketAPI.GeneratedCode.PlayerCamera();
-                }
-                PlayerCamera.MergeFrom(other.PlayerCamera);
-            }
-            if (other.inventoryUpgrades_ != null)
-            {
-                if (inventoryUpgrades_ == null)
-                {
-                    inventoryUpgrades_ = new global::PokemonGo.RocketAPI.GeneratedCode.InventoryUpgrades();
-                }
-                InventoryUpgrades.MergeFrom(other.InventoryUpgrades);
-            }
-            if (other.appliedItems_ != null)
-            {
-                if (appliedItems_ == null)
-                {
-                    appliedItems_ = new global::PokemonGo.RocketAPI.GeneratedCode.AppliedItems();
-                }
-                AppliedItems.MergeFrom(other.AppliedItems);
-            }
-            if (other.eggIncubators_ != null)
-            {
-                if (eggIncubators_ == null)
-                {
-                    eggIncubators_ = new global::PokemonGo.RocketAPI.GeneratedCode.EggIncubators();
-                }
-                EggIncubators.MergeFrom(other.EggIncubators);
-            }
-            if (other.pokemonFamily_ != null)
-            {
-                if (pokemonFamily_ == null)
-                {
-                    pokemonFamily_ = new global::PokemonGo.RocketAPI.GeneratedCode.PokemonFamily();
-                }
-                PokemonFamily.MergeFrom(other.PokemonFamily);
-            }
-        }
-
-        public void MergeFrom(pb::CodedInputStream input)
-        {
-            uint tag;
-            while ((tag = input.ReadTag()) != 0)
-            {
-                switch (tag)
-                {
-                    default:
-                        input.SkipLastField();
-                        break;
-                    case 10:
-                        {
-                            if (pokemon_ == null)
-                            {
-                                pokemon_ = new global::PokemonGo.RocketAPI.GeneratedCode.PokemonData();
-                            }
-                            input.ReadMessage(pokemon_);
-                            break;
-                        }
-                    case 18:
-                        {
-                            if (item_ == null)
-                            {
-                                item_ = new global::PokemonGo.RocketAPI.GeneratedCode.Item();
-                            }
-                            input.ReadMessage(item_);
-                            break;
-                        }
-                    case 26:
-                        {
-                            if (pokedexEntry_ == null)
-                            {
-                                pokedexEntry_ = new global::PokemonGo.RocketAPI.GeneratedCode.PokedexEntry();
-                            }
-                            input.ReadMessage(pokedexEntry_);
-                            break;
-                        }
-                    case 34:
-                        {
-                            if (playerStats_ == null)
-                            {
-                                playerStats_ = new global::PokemonGo.RocketAPI.GeneratedCode.PlayerStats();
-                            }
-                            input.ReadMessage(playerStats_);
-                            break;
-                        }
-                    case 42:
-                        {
-                            if (playerCurrency_ == null)
-                            {
-                                playerCurrency_ = new global::PokemonGo.RocketAPI.GeneratedCode.PlayerCurrency();
-                            }
-                            input.ReadMessage(playerCurrency_);
-                            break;
-                        }
-                    case 50:
-                        {
-                            if (playerCamera_ == null)
-                            {
-                                playerCamera_ = new global::PokemonGo.RocketAPI.GeneratedCode.PlayerCamera();
-                            }
-                            input.ReadMessage(playerCamera_);
-                            break;
-                        }
-                    case 58:
-                        {
-                            if (inventoryUpgrades_ == null)
-                            {
-                                inventoryUpgrades_ = new global::PokemonGo.RocketAPI.GeneratedCode.InventoryUpgrades();
-                            }
-                            input.ReadMessage(inventoryUpgrades_);
-                            break;
-                        }
-                    case 66:
-                        {
-                            if (appliedItems_ == null)
-                            {
-                                appliedItems_ = new global::PokemonGo.RocketAPI.GeneratedCode.AppliedItems();
-                            }
-                            input.ReadMessage(appliedItems_);
-                            break;
-                        }
-                    case 74:
-                        {
-                            if (eggIncubators_ == null)
-                            {
-                                eggIncubators_ = new global::PokemonGo.RocketAPI.GeneratedCode.EggIncubators();
-                            }
-                            input.ReadMessage(eggIncubators_);
-                            break;
-                        }
-                    case 82:
-                        {
-                            if (pokemonFamily_ == null)
-                            {
-                                pokemonFamily_ = new global::PokemonGo.RocketAPI.GeneratedCode.PokemonFamily();
-                            }
-                            input.ReadMessage(pokemonFamily_);
-                            break;
-                        }
-                }
-            }
-        }
-
-        public override bool Equals(object other)
-        {
-            return Equals(other as InventoryItemData);
-        }
-
-        public override int GetHashCode()
-        {
-            var hash = 1;
-            if (pokemon_ != null) hash ^= Pokemon.GetHashCode();
-            if (item_ != null) hash ^= Item.GetHashCode();
-            if (pokedexEntry_ != null) hash ^= PokedexEntry.GetHashCode();
-            if (playerStats_ != null) hash ^= PlayerStats.GetHashCode();
-            if (playerCurrency_ != null) hash ^= PlayerCurrency.GetHashCode();
-            if (playerCamera_ != null) hash ^= PlayerCamera.GetHashCode();
-            if (inventoryUpgrades_ != null) hash ^= InventoryUpgrades.GetHashCode();
-            if (appliedItems_ != null) hash ^= AppliedItems.GetHashCode();
-            if (eggIncubators_ != null) hash ^= EggIncubators.GetHashCode();
-            if (pokemonFamily_ != null) hash ^= PokemonFamily.GetHashCode();
-            return hash;
-        }
-
-        partial void OnConstruction();
-
-        public override string ToString()
-        {
-            return pb::JsonFormatter.ToDiagnosticString(this);
-        }
-    }
-
-    [global::System.Diagnostics.DebuggerNonUserCodeAttribute()]
-    public sealed partial class RecycleInventoryItem : pb::IMessage<RecycleInventoryItem>
-    {
-        /// <summary>Field number for the "item_id" field.</summary>
-        public const int ItemIdFieldNumber = 1;
-
-        /// <summary>Field number for the "count" field.</summary>
-        public const int CountFieldNumber = 2;
-
-        private static readonly pb::MessageParser<RecycleInventoryItem> _parser =
-            new pb::MessageParser<RecycleInventoryItem>(() => new RecycleInventoryItem());
-
-        private int count_;
-        private global::PokemonGo.RocketAPI.GeneratedCode.ItemId itemId_ = 0;
-
-        public RecycleInventoryItem()
-        {
-            OnConstruction();
-        }
-
-        public RecycleInventoryItem(RecycleInventoryItem other) : this()
-        {
-            itemId_ = other.itemId_;
-            count_ = other.count_;
-        }
-
-        public static pb::MessageParser<RecycleInventoryItem> Parser
-        {
-            get { return _parser; }
-        }
-
-        public static pbr::MessageDescriptor Descriptor
-        {
-            get { return global::PokemonGo.RocketAPI.GeneratedCode.PayloadsReflection.Descriptor.MessageTypes[10]; }
-        }
-
-        public global::PokemonGo.RocketAPI.GeneratedCode.ItemId ItemId
-        {
-            get { return itemId_; }
-            set { itemId_ = value; }
-        }
-
-        public int Count
-        {
-            get { return count_; }
-            set { count_ = value; }
-        }
-
-        pbr::MessageDescriptor pb::IMessage.Descriptor
-        {
-            get { return Descriptor; }
-        }
-
-        public RecycleInventoryItem Clone()
-        {
-            return new RecycleInventoryItem(this);
-        }
-
-        public bool Equals(RecycleInventoryItem other)
-        {
-            if (ReferenceEquals(other, null))
-            {
-                return false;
-            }
-            if (ReferenceEquals(other, this))
-            {
-                return true;
-            }
-            if (ItemId != other.ItemId) return false;
-            if (Count != other.Count) return false;
-            return true;
-        }
-
-        public void WriteTo(pb::CodedOutputStream output)
-        {
-            if (ItemId != 0)
-            {
-                output.WriteRawTag(8);
-                output.WriteEnum((int)ItemId);
-            }
-            if (Count != 0)
-            {
-                output.WriteRawTag(16);
-                output.WriteInt32(Count);
-            }
-        }
-
-        public int CalculateSize()
-        {
-            var size = 0;
-            if (ItemId != 0)
-            {
-                size += 1 + pb::CodedOutputStream.ComputeEnumSize((int)ItemId);
-            }
-            if (Count != 0)
-            {
-                size += 1 + pb::CodedOutputStream.ComputeInt32Size(Count);
-            }
-            return size;
-        }
-
-        public void MergeFrom(RecycleInventoryItem other)
-        {
-            if (other == null)
-            {
-                return;
-            }
-            if (other.ItemId != 0)
-            {
-                ItemId = other.ItemId;
-            }
-            if (other.Count != 0)
-            {
-                Count = other.Count;
-            }
-        }
-
-        public void MergeFrom(pb::CodedInputStream input)
-        {
-            uint tag;
-            while ((tag = input.ReadTag()) != 0)
-            {
-                switch (tag)
-                {
-                    default:
-                        input.SkipLastField();
-                        break;
-                    case 8:
-                        {
-                            itemId_ = (global::PokemonGo.RocketAPI.GeneratedCode.ItemId)input.ReadEnum();
-                            break;
-                        }
-                    case 16:
-                        {
-                            Count = input.ReadInt32();
-                            break;
-                        }
-                }
-            }
-        }
-
-        public override bool Equals(object other)
-        {
-            return Equals(other as RecycleInventoryItem);
-        }
-
-        public override int GetHashCode()
-        {
-            var hash = 1;
-            if (ItemId != 0) hash ^= ItemId.GetHashCode();
-            if (Count != 0) hash ^= Count.GetHashCode();
-            return hash;
-        }
-
-        partial void OnConstruction();
-
-        public override string ToString()
-        {
-            return pb::JsonFormatter.ToDiagnosticString(this);
-        }
-    }
-
-    [global::System.Diagnostics.DebuggerNonUserCodeAttribute()]
-    public sealed partial class Pokemon : pb::IMessage<Pokemon>
-    {
-        /// <summary>Field number for the "id" field.</summary>
-        public const int IdFieldNumber = 1;
-
-        /// <summary>Field number for the "pokemon_type" field.</summary>
-        public const int PokemonTypeFieldNumber = 2;
-
-        /// <summary>Field number for the "cp" field.</summary>
-        public const int CpFieldNumber = 3;
-
-        /// <summary>Field number for the "stamina" field.</summary>
-        public const int StaminaFieldNumber = 4;
-
-        /// <summary>Field number for the "stamina_max" field.</summary>
-        public const int StaminaMaxFieldNumber = 5;
-
-        /// <summary>Field number for the "move_1" field.</summary>
-        public const int Move1FieldNumber = 6;
-
-        /// <summary>Field number for the "move_2" field.</summary>
-        public const int Move2FieldNumber = 7;
-
-        /// <summary>Field number for the "deployed_fort_id" field.</summary>
-        public const int DeployedFortIdFieldNumber = 8;
-
-        /// <summary>Field number for the "owner_name" field.</summary>
-        public const int OwnerNameFieldNumber = 9;
-
-        /// <summary>Field number for the "is_egg" field.</summary>
-        public const int IsEggFieldNumber = 10;
-
-        /// <summary>Field number for the "egg_km_walked_target" field.</summary>
-        public const int EggKmWalkedTargetFieldNumber = 11;
-
-        /// <summary>Field number for the "egg_km_walked_start" field.</summary>
-        public const int EggKmWalkedStartFieldNumber = 12;
-
-        /// <summary>Field number for the "origin" field.</summary>
-        public const int OriginFieldNumber = 14;
-
-        /// <summary>Field number for the "height_m" field.</summary>
-        public const int HeightMFieldNumber = 15;
-
-        /// <summary>Field number for the "weight_kg" field.</summary>
-        public const int WeightKgFieldNumber = 16;
-
-        /// <summary>Field number for the "individual_attack" field.</summary>
-        public const int IndividualAttackFieldNumber = 17;
-
-        /// <summary>Field number for the "individual_defense" field.</summary>
-        public const int IndividualDefenseFieldNumber = 18;
-
-        /// <summary>Field number for the "individual_stamina" field.</summary>
-        public const int IndividualStaminaFieldNumber = 19;
-
-        /// <summary>Field number for the "cp_multiplier" field.</summary>
-        public const int CpMultiplierFieldNumber = 20;
-
-        /// <summary>Field number for the "pokeball" field.</summary>
-        public const int PokeballFieldNumber = 21;
-
-        /// <summary>Field number for the "captured_cell_id" field.</summary>
-        public const int CapturedCellIdFieldNumber = 22;
-
-        /// <summary>Field number for the "battles_attacked" field.</summary>
-        public const int BattlesAttackedFieldNumber = 23;
-
-        /// <summary>Field number for the "battles_defended" field.</summary>
-        public const int BattlesDefendedFieldNumber = 24;
-
-        /// <summary>Field number for the "egg_incubator_id" field.</summary>
-        public const int EggIncubatorIdFieldNumber = 25;
-
-        /// <summary>Field number for the "creation_time_ms" field.</summary>
-        public const int CreationTimeMsFieldNumber = 26;
-
-        /// <summary>Field number for the "num_upgrades" field.</summary>
-        public const int NumUpgradesFieldNumber = 27;
-
-        /// <summary>Field number for the "additional_cp_multiplier" field.</summary>
-        public const int AdditionalCpMultiplierFieldNumber = 28;
-
-        /// <summary>Field number for the "favorite" field.</summary>
-        public const int FavoriteFieldNumber = 29;
-
-        /// <summary>Field number for the "nickname" field.</summary>
-        public const int NicknameFieldNumber = 30;
-
-        /// <summary>Field number for the "from_fort" field.</summary>
-        public const int FromFortFieldNumber = 31;
-
-        private static readonly pb::MessageParser<Pokemon> _parser = new pb::MessageParser<Pokemon>(() => new Pokemon());
-        private float additionalCpMultiplier_;
-        private int battlesAttacked_;
-        private int battlesDefended_;
-        private ulong capturedCellId_;
-        private int cp_;
-        private float cpMultiplier_;
-        private ulong creationTimeMs_;
-        private int deployedFortId_;
-        private int eggIncubatorId_;
-        private int eggKmWalkedStart_;
-        private int eggKmWalkedTarget_;
-        private int favorite_;
-        private int fromFort_;
-        private float heightM_;
-        private int id_;
-        private int individualAttack_;
-        private int individualDefense_;
-        private int individualStamina_;
-        private bool isEgg_;
-        private global::PokemonGo.RocketAPI.GeneratedCode.PokemonMove move1_ = 0;
-        private global::PokemonGo.RocketAPI.GeneratedCode.PokemonMove move2_ = 0;
-        private string nickname_ = "";
-        private int numUpgrades_;
-        private int origin_;
-        private string ownerName_ = "";
-        private int pokeball_;
-        private global::PokemonGo.RocketAPI.GeneratedCode.PokemonId pokemonType_ = 0;
-        private int stamina_;
-        private int staminaMax_;
-        private float weightKg_;
-
-        public Pokemon()
-        {
-            OnConstruction();
-        }
-
-        public Pokemon(Pokemon other) : this()
-        {
-            id_ = other.id_;
-            pokemonType_ = other.pokemonType_;
-            cp_ = other.cp_;
-            stamina_ = other.stamina_;
-            staminaMax_ = other.staminaMax_;
-            move1_ = other.move1_;
-            move2_ = other.move2_;
-            deployedFortId_ = other.deployedFortId_;
-            ownerName_ = other.ownerName_;
-            isEgg_ = other.isEgg_;
-            eggKmWalkedTarget_ = other.eggKmWalkedTarget_;
-            eggKmWalkedStart_ = other.eggKmWalkedStart_;
-            origin_ = other.origin_;
-            heightM_ = other.heightM_;
-            weightKg_ = other.weightKg_;
-            individualAttack_ = other.individualAttack_;
-            individualDefense_ = other.individualDefense_;
-            individualStamina_ = other.individualStamina_;
-            cpMultiplier_ = other.cpMultiplier_;
-            pokeball_ = other.pokeball_;
-            capturedCellId_ = other.capturedCellId_;
-            battlesAttacked_ = other.battlesAttacked_;
-            battlesDefended_ = other.battlesDefended_;
-            eggIncubatorId_ = other.eggIncubatorId_;
-            creationTimeMs_ = other.creationTimeMs_;
-            numUpgrades_ = other.numUpgrades_;
-            additionalCpMultiplier_ = other.additionalCpMultiplier_;
-            favorite_ = other.favorite_;
-            nickname_ = other.nickname_;
-            fromFort_ = other.fromFort_;
-        }
-
-        public static pb::MessageParser<Pokemon> Parser
-        {
-            get { return _parser; }
-        }
-
-        public static pbr::MessageDescriptor Descriptor
-        {
-            get { return global::PokemonGo.RocketAPI.GeneratedCode.PayloadsReflection.Descriptor.MessageTypes[11]; }
-        }
-
-        public int Id
-        {
-            get { return id_; }
-            set { id_ = value; }
-        }
-
-        public global::PokemonGo.RocketAPI.GeneratedCode.PokemonId PokemonType
-        {
-            get { return pokemonType_; }
-            set { pokemonType_ = value; }
-        }
-
-        public int Cp
-        {
-            get { return cp_; }
-            set { cp_ = value; }
-        }
-
-        public int Stamina
-        {
-            get { return stamina_; }
-            set { stamina_ = value; }
-        }
-
-        public int StaminaMax
-        {
-            get { return staminaMax_; }
-            set { staminaMax_ = value; }
-        }
-
-        public global::PokemonGo.RocketAPI.GeneratedCode.PokemonMove Move1
-        {
-            get { return move1_; }
-            set { move1_ = value; }
-        }
-
-        public global::PokemonGo.RocketAPI.GeneratedCode.PokemonMove Move2
-        {
-            get { return move2_; }
-            set { move2_ = value; }
-        }
-
-        public int DeployedFortId
-        {
-            get { return deployedFortId_; }
-            set { deployedFortId_ = value; }
-        }
-
-        public string OwnerName
-        {
-            get { return ownerName_; }
-            set { ownerName_ = pb::ProtoPreconditions.CheckNotNull(value, "value"); }
-        }
-
-        public bool IsEgg
-        {
-            get { return isEgg_; }
-            set { isEgg_ = value; }
-        }
-
-        public int EggKmWalkedTarget
-        {
-            get { return eggKmWalkedTarget_; }
-            set { eggKmWalkedTarget_ = value; }
-        }
-
-        public int EggKmWalkedStart
-        {
-            get { return eggKmWalkedStart_; }
-            set { eggKmWalkedStart_ = value; }
-        }
-
-        public int Origin
-        {
-            get { return origin_; }
-            set { origin_ = value; }
-        }
-
-        public float HeightM
-        {
-            get { return heightM_; }
-            set { heightM_ = value; }
-        }
-
-        public float WeightKg
-        {
-            get { return weightKg_; }
-            set { weightKg_ = value; }
-        }
-
-        public int IndividualAttack
-        {
-            get { return individualAttack_; }
-            set { individualAttack_ = value; }
-        }
-
-        public int IndividualDefense
-        {
-            get { return individualDefense_; }
-            set { individualDefense_ = value; }
-        }
-
-        public int IndividualStamina
-        {
-            get { return individualStamina_; }
-            set { individualStamina_ = value; }
-        }
-
-        public float CpMultiplier
-        {
-            get { return cpMultiplier_; }
-            set { cpMultiplier_ = value; }
-        }
-
-        public int Pokeball
-        {
-            get { return pokeball_; }
-            set { pokeball_ = value; }
-        }
-
-        public ulong CapturedCellId
-        {
-            get { return capturedCellId_; }
-            set { capturedCellId_ = value; }
-        }
-
-        public int BattlesAttacked
-        {
-            get { return battlesAttacked_; }
-            set { battlesAttacked_ = value; }
-        }
-
-        public int BattlesDefended
-        {
-            get { return battlesDefended_; }
-            set { battlesDefended_ = value; }
-        }
-
-        public int EggIncubatorId
-        {
-            get { return eggIncubatorId_; }
-            set { eggIncubatorId_ = value; }
-        }
-
-        public ulong CreationTimeMs
-        {
-            get { return creationTimeMs_; }
-            set { creationTimeMs_ = value; }
-        }
-
-        public int NumUpgrades
-        {
-            get { return numUpgrades_; }
-            set { numUpgrades_ = value; }
-        }
-
-        public float AdditionalCpMultiplier
-        {
-            get { return additionalCpMultiplier_; }
-            set { additionalCpMultiplier_ = value; }
-        }
-
-        public int Favorite
-        {
-            get { return favorite_; }
-            set { favorite_ = value; }
-        }
-
-        public string Nickname
-        {
-            get { return nickname_; }
-            set { nickname_ = pb::ProtoPreconditions.CheckNotNull(value, "value"); }
-        }
-
-        public int FromFort
-        {
-            get { return fromFort_; }
-            set { fromFort_ = value; }
-        }
-
-        pbr::MessageDescriptor pb::IMessage.Descriptor
-        {
-            get { return Descriptor; }
-        }
-
-        public Pokemon Clone()
-        {
-            return new Pokemon(this);
-        }
-
-        public bool Equals(Pokemon other)
-        {
-            if (ReferenceEquals(other, null))
-            {
-                return false;
-            }
-            if (ReferenceEquals(other, this))
-            {
-                return true;
-            }
-            if (Id != other.Id) return false;
-            if (PokemonType != other.PokemonType) return false;
-            if (Cp != other.Cp) return false;
-            if (Stamina != other.Stamina) return false;
-            if (StaminaMax != other.StaminaMax) return false;
-            if (Move1 != other.Move1) return false;
-            if (Move2 != other.Move2) return false;
-            if (DeployedFortId != other.DeployedFortId) return false;
-            if (OwnerName != other.OwnerName) return false;
-            if (IsEgg != other.IsEgg) return false;
-            if (EggKmWalkedTarget != other.EggKmWalkedTarget) return false;
-            if (EggKmWalkedStart != other.EggKmWalkedStart) return false;
-            if (Origin != other.Origin) return false;
-            if (HeightM != other.HeightM) return false;
-            if (WeightKg != other.WeightKg) return false;
-            if (IndividualAttack != other.IndividualAttack) return false;
-            if (IndividualDefense != other.IndividualDefense) return false;
-            if (IndividualStamina != other.IndividualStamina) return false;
-            if (CpMultiplier != other.CpMultiplier) return false;
-            if (Pokeball != other.Pokeball) return false;
-            if (CapturedCellId != other.CapturedCellId) return false;
-            if (BattlesAttacked != other.BattlesAttacked) return false;
-            if (BattlesDefended != other.BattlesDefended) return false;
-            if (EggIncubatorId != other.EggIncubatorId) return false;
-            if (CreationTimeMs != other.CreationTimeMs) return false;
-            if (NumUpgrades != other.NumUpgrades) return false;
-            if (AdditionalCpMultiplier != other.AdditionalCpMultiplier) return false;
-            if (Favorite != other.Favorite) return false;
-            if (Nickname != other.Nickname) return false;
-            if (FromFort != other.FromFort) return false;
-            return true;
-        }
-
-        public void WriteTo(pb::CodedOutputStream output)
-        {
-            if (Id != 0)
-            {
-                output.WriteRawTag(8);
-                output.WriteInt32(Id);
-            }
-            if (PokemonType != 0)
-            {
-                output.WriteRawTag(16);
-                output.WriteEnum((int)PokemonType);
-            }
-            if (Cp != 0)
-            {
-                output.WriteRawTag(24);
-                output.WriteInt32(Cp);
-            }
-            if (Stamina != 0)
-            {
-                output.WriteRawTag(32);
-                output.WriteInt32(Stamina);
-            }
-            if (StaminaMax != 0)
-            {
-                output.WriteRawTag(40);
-                output.WriteInt32(StaminaMax);
-            }
-            if (Move1 != 0)
-            {
-                output.WriteRawTag(48);
-                output.WriteEnum((int)Move1);
-            }
-            if (Move2 != 0)
-            {
-                output.WriteRawTag(56);
-                output.WriteEnum((int)Move2);
-            }
-            if (DeployedFortId != 0)
-            {
-                output.WriteRawTag(64);
-                output.WriteInt32(DeployedFortId);
-            }
-            if (OwnerName.Length != 0)
-            {
-                output.WriteRawTag(74);
-                output.WriteString(OwnerName);
-            }
-            if (IsEgg != false)
-            {
-                output.WriteRawTag(80);
-                output.WriteBool(IsEgg);
-            }
-            if (EggKmWalkedTarget != 0)
-            {
-                output.WriteRawTag(88);
-                output.WriteInt32(EggKmWalkedTarget);
-            }
-            if (EggKmWalkedStart != 0)
-            {
-                output.WriteRawTag(96);
-                output.WriteInt32(EggKmWalkedStart);
-            }
-            if (Origin != 0)
-            {
-                output.WriteRawTag(112);
-                output.WriteInt32(Origin);
-            }
-            if (HeightM != 0F)
-            {
-                output.WriteRawTag(125);
-                output.WriteFloat(HeightM);
-            }
-            if (WeightKg != 0F)
-            {
-                output.WriteRawTag(133, 1);
-                output.WriteFloat(WeightKg);
-            }
-            if (IndividualAttack != 0)
-            {
-                output.WriteRawTag(136, 1);
-                output.WriteInt32(IndividualAttack);
-            }
-            if (IndividualDefense != 0)
-            {
-                output.WriteRawTag(144, 1);
-                output.WriteInt32(IndividualDefense);
-            }
-            if (IndividualStamina != 0)
-            {
-                output.WriteRawTag(152, 1);
-                output.WriteInt32(IndividualStamina);
-            }
-            if (CpMultiplier != 0)
-            {
-                output.WriteRawTag(165, 1);
-                output.WriteFloat(CpMultiplier);
-            }
-            if (Pokeball != 0)
-            {
-                output.WriteRawTag(168, 1);
-                output.WriteInt32(Pokeball);
-            }
-            if (CapturedCellId != 0UL)
-            {
-                output.WriteRawTag(176, 1);
-                output.WriteUInt64(CapturedCellId);
-            }
-            if (BattlesAttacked != 0)
-            {
-                output.WriteRawTag(184, 1);
-                output.WriteInt32(BattlesAttacked);
-            }
-            if (BattlesDefended != 0)
-            {
-                output.WriteRawTag(192, 1);
-                output.WriteInt32(BattlesDefended);
-            }
-            if (EggIncubatorId != 0)
-            {
-                output.WriteRawTag(200, 1);
-                output.WriteInt32(EggIncubatorId);
-            }
-            if (CreationTimeMs != 0UL)
-            {
-                output.WriteRawTag(208, 1);
-                output.WriteUInt64(CreationTimeMs);
-            }
-            if (NumUpgrades != 0)
-            {
-                output.WriteRawTag(216, 1);
-                output.WriteInt32(NumUpgrades);
-            }
-            if (AdditionalCpMultiplier != 0)
-            {
-                output.WriteRawTag(229, 1);
-                output.WriteFloat(AdditionalCpMultiplier);
-            }
-            if (Favorite != 0)
-            {
-                output.WriteRawTag(232, 1);
-                output.WriteInt32(Favorite);
-            }
-            if (Nickname.Length != 0)
-            {
-                output.WriteRawTag(242, 1);
-                output.WriteString(Nickname);
-            }
-            if (FromFort != 0)
-            {
-                output.WriteRawTag(248, 1);
-                output.WriteInt32(FromFort);
-            }
-        }
-
-        public int CalculateSize()
-        {
-            var size = 0;
-            if (Id != 0)
-            {
-                size += 1 + pb::CodedOutputStream.ComputeInt32Size(Id);
-            }
-            if (PokemonType != 0)
-            {
-                size += 1 + pb::CodedOutputStream.ComputeEnumSize((int)PokemonType);
-            }
-            if (Cp != 0)
-            {
-                size += 1 + pb::CodedOutputStream.ComputeInt32Size(Cp);
-            }
-            if (Stamina != 0)
-            {
-                size += 1 + pb::CodedOutputStream.ComputeInt32Size(Stamina);
-            }
-            if (StaminaMax != 0)
-            {
-                size += 1 + pb::CodedOutputStream.ComputeInt32Size(StaminaMax);
-            }
-            if (Move1 != 0)
-            {
-                size += 1 + pb::CodedOutputStream.ComputeEnumSize((int)Move1);
-            }
-            if (Move2 != 0)
-            {
-                size += 1 + pb::CodedOutputStream.ComputeEnumSize((int)Move2);
-            }
-            if (DeployedFortId != 0)
-            {
-                size += 1 + pb::CodedOutputStream.ComputeInt32Size(DeployedFortId);
-            }
-            if (OwnerName.Length != 0)
-            {
-                size += 1 + pb::CodedOutputStream.ComputeStringSize(OwnerName);
-            }
-            if (IsEgg != false)
-            {
-                size += 1 + 1;
-            }
-            if (EggKmWalkedTarget != 0)
-            {
-                size += 1 + pb::CodedOutputStream.ComputeInt32Size(EggKmWalkedTarget);
-            }
-            if (EggKmWalkedStart != 0)
-            {
-                size += 1 + pb::CodedOutputStream.ComputeInt32Size(EggKmWalkedStart);
-            }
-            if (Origin != 0)
-            {
-                size += 1 + pb::CodedOutputStream.ComputeInt32Size(Origin);
-            }
-            if (HeightM != 0F)
-            {
-                size += 1 + 4;
-            }
-            if (WeightKg != 0F)
-            {
-                size += 2 + 4;
-            }
-            if (IndividualAttack != 0)
-            {
-                size += 2 + pb::CodedOutputStream.ComputeInt32Size(IndividualAttack);
-            }
-            if (IndividualDefense != 0)
-            {
-                size += 2 + pb::CodedOutputStream.ComputeInt32Size(IndividualDefense);
-            }
-            if (IndividualStamina != 0)
-            {
-                size += 2 + pb::CodedOutputStream.ComputeInt32Size(IndividualStamina);
-            }
-            if (CpMultiplier != 0F)
-            {
-                size += 2 + 4;
-            }
-            if (Pokeball != 0)
-            {
-                size += 2 + pb::CodedOutputStream.ComputeInt32Size(Pokeball);
-            }
-            if (CapturedCellId != 0UL)
-            {
-                size += 2 + pb::CodedOutputStream.ComputeUInt64Size(CapturedCellId);
-            }
-            if (BattlesAttacked != 0)
-            {
-                size += 2 + pb::CodedOutputStream.ComputeInt32Size(BattlesAttacked);
-            }
-            if (BattlesDefended != 0)
-            {
-                size += 2 + pb::CodedOutputStream.ComputeInt32Size(BattlesDefended);
-            }
-            if (EggIncubatorId != 0)
-            {
-                size += 2 + pb::CodedOutputStream.ComputeInt32Size(EggIncubatorId);
-            }
-            if (CreationTimeMs != 0UL)
-            {
-                size += 2 + pb::CodedOutputStream.ComputeUInt64Size(CreationTimeMs);
-            }
-            if (NumUpgrades != 0)
-            {
-                size += 2 + pb::CodedOutputStream.ComputeInt32Size(NumUpgrades);
-            }
-            if (AdditionalCpMultiplier != 0F)
-            {
-                size += 2 + 4;
-            }
-            if (Favorite != 0)
-            {
-                size += 2 + pb::CodedOutputStream.ComputeInt32Size(Favorite);
-            }
-            if (Nickname.Length != 0)
-            {
-                size += 2 + pb::CodedOutputStream.ComputeStringSize(Nickname);
-            }
-            if (FromFort != 0)
-            {
-                size += 2 + pb::CodedOutputStream.ComputeInt32Size(FromFort);
-            }
-            return size;
-        }
-
-        public void MergeFrom(Pokemon other)
-        {
-            if (other == null)
-            {
-                return;
-            }
-            if (other.Id != 0)
-            {
-                Id = other.Id;
-            }
-            if (other.PokemonType != 0)
-            {
-                PokemonType = other.PokemonType;
-            }
-            if (other.Cp != 0)
-            {
-                Cp = other.Cp;
-            }
-            if (other.Stamina != 0)
-            {
-                Stamina = other.Stamina;
-            }
-            if (other.StaminaMax != 0)
-            {
-                StaminaMax = other.StaminaMax;
-            }
-            if (other.Move1 != 0)
-            {
-                Move1 = other.Move1;
-            }
-            if (other.Move2 != 0)
-            {
-                Move2 = other.Move2;
-            }
-            if (other.DeployedFortId != 0)
-            {
-                DeployedFortId = other.DeployedFortId;
-            }
-            if (other.OwnerName.Length != 0)
-            {
-                OwnerName = other.OwnerName;
-            }
-            if (other.IsEgg != false)
-            {
-                IsEgg = other.IsEgg;
-            }
-            if (other.EggKmWalkedTarget != 0)
-            {
-                EggKmWalkedTarget = other.EggKmWalkedTarget;
-            }
-            if (other.EggKmWalkedStart != 0)
-            {
-                EggKmWalkedStart = other.EggKmWalkedStart;
-            }
-            if (other.Origin != 0)
-            {
-                Origin = other.Origin;
-            }
-            if (other.HeightM != 0F)
-            {
-                HeightM = other.HeightM;
-            }
-            if (other.WeightKg != 0F)
-            {
-                WeightKg = other.WeightKg;
-            }
-            if (other.IndividualAttack != 0)
-            {
-                IndividualAttack = other.IndividualAttack;
-            }
-            if (other.IndividualDefense != 0)
-            {
-                IndividualDefense = other.IndividualDefense;
-            }
-            if (other.IndividualStamina != 0)
-            {
-                IndividualStamina = other.IndividualStamina;
-            }
-            if (other.CpMultiplier != 0)
-            {
-                CpMultiplier = other.CpMultiplier;
-            }
-            if (other.Pokeball != 0)
-            {
-                Pokeball = other.Pokeball;
-            }
-            if (other.CapturedCellId != 0UL)
-            {
-                CapturedCellId = other.CapturedCellId;
-            }
-            if (other.BattlesAttacked != 0)
-            {
-                BattlesAttacked = other.BattlesAttacked;
-            }
-            if (other.BattlesDefended != 0)
-            {
-                BattlesDefended = other.BattlesDefended;
-            }
-            if (other.EggIncubatorId != 0)
-            {
-                EggIncubatorId = other.EggIncubatorId;
-            }
-            if (other.CreationTimeMs != 0UL)
-            {
-                CreationTimeMs = other.CreationTimeMs;
-            }
-            if (other.NumUpgrades != 0)
-            {
-                NumUpgrades = other.NumUpgrades;
-            }
-            if (other.AdditionalCpMultiplier != 0)
-            {
-                AdditionalCpMultiplier = other.AdditionalCpMultiplier;
-            }
-            if (other.Favorite != 0)
-            {
-                Favorite = other.Favorite;
-            }
-            if (other.Nickname.Length != 0)
-            {
-                Nickname = other.Nickname;
-            }
-            if (other.FromFort != 0)
-            {
-                FromFort = other.FromFort;
-            }
-        }
-
-        public void MergeFrom(pb::CodedInputStream input)
-        {
-            uint tag;
-            while ((tag = input.ReadTag()) != 0)
-            {
-                switch (tag)
-                {
-                    default:
-                        input.SkipLastField();
-                        break;
-                    case 8:
-                        {
-                            Id = input.ReadInt32();
-                            break;
-                        }
-                    case 16:
-                        {
-                            pokemonType_ = (global::PokemonGo.RocketAPI.GeneratedCode.PokemonId)input.ReadEnum();
-                            break;
-                        }
-                    case 24:
-                        {
-                            Cp = input.ReadInt32();
-                            break;
-                        }
-                    case 32:
-                        {
-                            Stamina = input.ReadInt32();
-                            break;
-                        }
-                    case 40:
-                        {
-                            StaminaMax = input.ReadInt32();
-                            break;
-                        }
-                    case 48:
-                        {
-                            move1_ = (global::PokemonGo.RocketAPI.GeneratedCode.PokemonMove)input.ReadEnum();
-                            break;
-                        }
-                    case 56:
-                        {
-                            move2_ = (global::PokemonGo.RocketAPI.GeneratedCode.PokemonMove)input.ReadEnum();
-                            break;
-                        }
-                    case 64:
-                        {
-                            DeployedFortId = input.ReadInt32();
-                            break;
-                        }
-                    case 74:
-                        {
-                            OwnerName = input.ReadString();
-                            break;
-                        }
-                    case 80:
-                        {
-                            IsEgg = input.ReadBool();
-                            break;
-                        }
-                    case 88:
-                        {
-                            EggKmWalkedTarget = input.ReadInt32();
-                            break;
-                        }
-                    case 96:
-                        {
-                            EggKmWalkedStart = input.ReadInt32();
-                            break;
-                        }
-                    case 112:
-                        {
-                            Origin = input.ReadInt32();
-                            break;
-                        }
-                    case 125:
-                        {
-                            HeightM = input.ReadFloat();
-                            break;
-                        }
-                    case 133:
-                        {
-                            WeightKg = input.ReadFloat();
-                            break;
-                        }
-                    case 136:
-                        {
-                            IndividualAttack = input.ReadInt32();
-                            break;
-                        }
-                    case 144:
-                        {
-                            IndividualDefense = input.ReadInt32();
-                            break;
-                        }
-                    case 152:
-                        {
-                            IndividualStamina = input.ReadInt32();
-                            break;
-                        }
-                    case 165:
-                        {
-                            CpMultiplier = input.ReadFloat();
-                            break;
-                        }
-                    case 168:
-                        {
-                            Pokeball = input.ReadInt32();
-                            break;
-                        }
-                    case 176:
-                        {
-                            CapturedCellId = input.ReadUInt64();
-                            break;
-                        }
-                    case 184:
-                        {
-                            BattlesAttacked = input.ReadInt32();
-                            break;
-                        }
-                    case 192:
-                        {
-                            BattlesDefended = input.ReadInt32();
-                            break;
-                        }
-                    case 200:
-                        {
-                            EggIncubatorId = input.ReadInt32();
-                            break;
-                        }
-                    case 208:
-                        {
-                            CreationTimeMs = input.ReadUInt64();
-                            break;
-                        }
-                    case 216:
-                        {
-                            NumUpgrades = input.ReadInt32();
-                            break;
-                        }
-                    case 229:
-                        {
-                            AdditionalCpMultiplier = input.ReadFloat();
-                            break;
-                        }
-                    case 232:
-                        {
-                            Favorite = input.ReadInt32();
-                            break;
-                        }
-                    case 242:
-                        {
-                            Nickname = input.ReadString();
-                            break;
-                        }
-                    case 248:
-                        {
-                            FromFort = input.ReadInt32();
-                            break;
-                        }
-                }
-            }
-        }
-
-        public override bool Equals(object other)
-        {
-            return Equals(other as Pokemon);
-        }
-
-        public override int GetHashCode()
-        {
-            var hash = 1;
-            if (Id != 0) hash ^= Id.GetHashCode();
-            if (PokemonType != 0) hash ^= PokemonType.GetHashCode();
-            if (Cp != 0) hash ^= Cp.GetHashCode();
-            if (Stamina != 0) hash ^= Stamina.GetHashCode();
-            if (StaminaMax != 0) hash ^= StaminaMax.GetHashCode();
-            if (Move1 != 0) hash ^= Move1.GetHashCode();
-            if (Move2 != 0) hash ^= Move2.GetHashCode();
-            if (DeployedFortId != 0) hash ^= DeployedFortId.GetHashCode();
-            if (OwnerName.Length != 0) hash ^= OwnerName.GetHashCode();
-            if (IsEgg != false) hash ^= IsEgg.GetHashCode();
-            if (EggKmWalkedTarget != 0) hash ^= EggKmWalkedTarget.GetHashCode();
-            if (EggKmWalkedStart != 0) hash ^= EggKmWalkedStart.GetHashCode();
-            if (Origin != 0) hash ^= Origin.GetHashCode();
-            if (HeightM != 0F) hash ^= HeightM.GetHashCode();
-            if (WeightKg != 0F) hash ^= WeightKg.GetHashCode();
-            if (IndividualAttack != 0) hash ^= IndividualAttack.GetHashCode();
-            if (IndividualDefense != 0) hash ^= IndividualDefense.GetHashCode();
-            if (IndividualStamina != 0) hash ^= IndividualStamina.GetHashCode();
-            if (CpMultiplier != 0) hash ^= CpMultiplier.GetHashCode();
-            if (Pokeball != 0) hash ^= Pokeball.GetHashCode();
-            if (CapturedCellId != 0UL) hash ^= CapturedCellId.GetHashCode();
-            if (BattlesAttacked != 0) hash ^= BattlesAttacked.GetHashCode();
-            if (BattlesDefended != 0) hash ^= BattlesDefended.GetHashCode();
-            if (EggIncubatorId != 0) hash ^= EggIncubatorId.GetHashCode();
-            if (CreationTimeMs != 0UL) hash ^= CreationTimeMs.GetHashCode();
-            if (NumUpgrades != 0) hash ^= NumUpgrades.GetHashCode();
-            if (AdditionalCpMultiplier != 0) hash ^= AdditionalCpMultiplier.GetHashCode();
-            if (Favorite != 0) hash ^= Favorite.GetHashCode();
-            if (Nickname.Length != 0) hash ^= Nickname.GetHashCode();
-            if (FromFort != 0) hash ^= FromFort.GetHashCode();
-            return hash;
-        }
-
-        partial void OnConstruction();
-
-        public override string ToString()
-        {
-            return pb::JsonFormatter.ToDiagnosticString(this);
-        }
-    }
-
-    [global::System.Diagnostics.DebuggerNonUserCodeAttribute()]
-    public sealed partial class Item : pb::IMessage<Item>
-    {
-        /// <summary>Field number for the "item" field.</summary>
-        public const int Item_FieldNumber = 1;
-
-        /// <summary>Field number for the "count" field.</summary>
-        public const int CountFieldNumber = 2;
-
-        /// <summary>Field number for the "unseen" field.</summary>
-        public const int UnseenFieldNumber = 3;
-
-        private static readonly pb::MessageParser<Item> _parser = new pb::MessageParser<Item>(() => new Item());
-        private int count_;
-        private global::PokemonGo.RocketAPI.GeneratedCode.ItemType item_ = 0;
-        private bool unseen_;
-
-        public Item()
-        {
-            OnConstruction();
-        }
-
-        public Item(Item other) : this()
-        {
-            item_ = other.item_;
-            count_ = other.count_;
-            unseen_ = other.unseen_;
-        }
-
-        public static pb::MessageParser<Item> Parser
-        {
-            get { return _parser; }
-        }
-
-        public static pbr::MessageDescriptor Descriptor
-        {
-            get { return global::PokemonGo.RocketAPI.GeneratedCode.PayloadsReflection.Descriptor.MessageTypes[12]; }
-        }
-
-        public global::PokemonGo.RocketAPI.GeneratedCode.ItemType Item_
-        {
-            get { return item_; }
-            set { item_ = value; }
-        }
-
-        public int Count
-        {
-            get { return count_; }
-            set { count_ = value; }
-        }
-
-        public bool Unseen
-        {
-            get { return unseen_; }
-            set { unseen_ = value; }
-        }
-
-        pbr::MessageDescriptor pb::IMessage.Descriptor
-        {
-            get { return Descriptor; }
-        }
-
-        public Item Clone()
-        {
-            return new Item(this);
-        }
-
-        public bool Equals(Item other)
-        {
-            if (ReferenceEquals(other, null))
-            {
-                return false;
-            }
-            if (ReferenceEquals(other, this))
-            {
-                return true;
-            }
-            if (Item_ != other.Item_) return false;
-            if (Count != other.Count) return false;
-            if (Unseen != other.Unseen) return false;
-            return true;
-        }
-
-        public void WriteTo(pb::CodedOutputStream output)
-        {
-            if (Item_ != 0)
-            {
-                output.WriteRawTag(8);
-                output.WriteEnum((int)Item_);
-            }
-            if (Count != 0)
-            {
-                output.WriteRawTag(16);
-                output.WriteInt32(Count);
-            }
-            if (Unseen != false)
-            {
-                output.WriteRawTag(24);
-                output.WriteBool(Unseen);
-            }
-        }
-
-        public int CalculateSize()
-        {
-            var size = 0;
-            if (Item_ != 0)
-            {
-                size += 1 + pb::CodedOutputStream.ComputeEnumSize((int)Item_);
-            }
-            if (Count != 0)
-            {
-                size += 1 + pb::CodedOutputStream.ComputeInt32Size(Count);
-            }
-            if (Unseen != false)
-            {
-                size += 1 + 1;
-            }
-            return size;
-        }
-
-        public void MergeFrom(Item other)
-        {
-            if (other == null)
-            {
-                return;
-            }
-            if (other.Item_ != 0)
-            {
-                Item_ = other.Item_;
-            }
-            if (other.Count != 0)
-            {
-                Count = other.Count;
-            }
-            if (other.Unseen != false)
-            {
-                Unseen = other.Unseen;
-            }
-        }
-
-        public void MergeFrom(pb::CodedInputStream input)
-        {
-            uint tag;
-            while ((tag = input.ReadTag()) != 0)
-            {
-                switch (tag)
-                {
-                    default:
-                        input.SkipLastField();
-                        break;
-                    case 8:
-                        {
-                            item_ = (global::PokemonGo.RocketAPI.GeneratedCode.ItemType)input.ReadEnum();
-                            break;
-                        }
-                    case 16:
-                        {
-                            Count = input.ReadInt32();
-                            break;
-                        }
-                    case 24:
-                        {
-                            Unseen = input.ReadBool();
-                            break;
-                        }
-                }
-            }
-        }
-
-        public override bool Equals(object other)
-        {
-            return Equals(other as Item);
-        }
-
-        public override int GetHashCode()
-        {
-            var hash = 1;
-            if (Item_ != 0) hash ^= Item_.GetHashCode();
-            if (Count != 0) hash ^= Count.GetHashCode();
-            if (Unseen != false) hash ^= Unseen.GetHashCode();
-            return hash;
-        }
-
-        partial void OnConstruction();
-
-        public override string ToString()
-        {
-            return pb::JsonFormatter.ToDiagnosticString(this);
-        }
-    }
-
-    [global::System.Diagnostics.DebuggerNonUserCodeAttribute()]
-    public sealed partial class PokedexEntry : pb::IMessage<PokedexEntry>
-    {
-        /// <summary>Field number for the "pokedex_entry_number" field.</summary>
-        public const int PokedexEntryNumberFieldNumber = 1;
-
-        /// <summary>Field number for the "times_encountered" field.</summary>
-        public const int TimesEncounteredFieldNumber = 2;
-
-        /// <summary>Field number for the "times_captured" field.</summary>
-        public const int TimesCapturedFieldNumber = 3;
-
-        /// <summary>Field number for the "evolution_stone_pieces" field.</summary>
-        public const int EvolutionStonePiecesFieldNumber = 4;
-
-        /// <summary>Field number for the "evolution_stones" field.</summary>
-        public const int EvolutionStonesFieldNumber = 5;
-
-        private static readonly pb::MessageParser<PokedexEntry> _parser =
-            new pb::MessageParser<PokedexEntry>(() => new PokedexEntry());
-
-        private int evolutionStonePieces_;
-        private int evolutionStones_;
-        private int pokedexEntryNumber_;
-        private int timesCaptured_;
-        private int timesEncountered_;
-
-        public PokedexEntry()
-        {
-            OnConstruction();
-        }
-
-        public PokedexEntry(PokedexEntry other) : this()
-        {
-            pokedexEntryNumber_ = other.pokedexEntryNumber_;
-            timesEncountered_ = other.timesEncountered_;
-            timesCaptured_ = other.timesCaptured_;
-            evolutionStonePieces_ = other.evolutionStonePieces_;
-            evolutionStones_ = other.evolutionStones_;
-        }
-
-        public static pb::MessageParser<PokedexEntry> Parser
-        {
-            get { return _parser; }
-        }
-
-        public static pbr::MessageDescriptor Descriptor
-        {
-            get { return global::PokemonGo.RocketAPI.GeneratedCode.PayloadsReflection.Descriptor.MessageTypes[13]; }
-        }
-
-        public int PokedexEntryNumber
-        {
-            get { return pokedexEntryNumber_; }
-            set { pokedexEntryNumber_ = value; }
-        }
-
-        public int TimesEncountered
-        {
-            get { return timesEncountered_; }
-            set { timesEncountered_ = value; }
-        }
-
-        public int TimesCaptured
-        {
-            get { return timesCaptured_; }
-            set { timesCaptured_ = value; }
-        }
-
-        public int EvolutionStonePieces
-        {
-            get { return evolutionStonePieces_; }
-            set { evolutionStonePieces_ = value; }
-        }
-
-        public int EvolutionStones
-        {
-            get { return evolutionStones_; }
-            set { evolutionStones_ = value; }
-        }
-
-        pbr::MessageDescriptor pb::IMessage.Descriptor
-        {
-            get { return Descriptor; }
-        }
-
-        public PokedexEntry Clone()
-        {
-            return new PokedexEntry(this);
-        }
-
-        public bool Equals(PokedexEntry other)
-        {
-            if (ReferenceEquals(other, null))
-            {
-                return false;
-            }
-            if (ReferenceEquals(other, this))
-            {
-                return true;
-            }
-            if (PokedexEntryNumber != other.PokedexEntryNumber) return false;
-            if (TimesEncountered != other.TimesEncountered) return false;
-            if (TimesCaptured != other.TimesCaptured) return false;
-            if (EvolutionStonePieces != other.EvolutionStonePieces) return false;
-            if (EvolutionStones != other.EvolutionStones) return false;
-            return true;
-        }
-
-        public void WriteTo(pb::CodedOutputStream output)
-        {
-            if (PokedexEntryNumber != 0)
-            {
-                output.WriteRawTag(8);
-                output.WriteInt32(PokedexEntryNumber);
-            }
-            if (TimesEncountered != 0)
-            {
-                output.WriteRawTag(16);
-                output.WriteInt32(TimesEncountered);
-            }
-            if (TimesCaptured != 0)
-            {
-                output.WriteRawTag(24);
-                output.WriteInt32(TimesCaptured);
-            }
-            if (EvolutionStonePieces != 0)
-            {
-                output.WriteRawTag(32);
-                output.WriteInt32(EvolutionStonePieces);
-            }
-            if (EvolutionStones != 0)
-            {
-                output.WriteRawTag(40);
-                output.WriteInt32(EvolutionStones);
-            }
-        }
-
-        public int CalculateSize()
-        {
-            var size = 0;
-            if (PokedexEntryNumber != 0)
-            {
-                size += 1 + pb::CodedOutputStream.ComputeInt32Size(PokedexEntryNumber);
-            }
-            if (TimesEncountered != 0)
-            {
-                size += 1 + pb::CodedOutputStream.ComputeInt32Size(TimesEncountered);
-            }
-            if (TimesCaptured != 0)
-            {
-                size += 1 + pb::CodedOutputStream.ComputeInt32Size(TimesCaptured);
-            }
-            if (EvolutionStonePieces != 0)
-            {
-                size += 1 + pb::CodedOutputStream.ComputeInt32Size(EvolutionStonePieces);
-            }
-            if (EvolutionStones != 0)
-            {
-                size += 1 + pb::CodedOutputStream.ComputeInt32Size(EvolutionStones);
-            }
-            return size;
-        }
-
-        public void MergeFrom(PokedexEntry other)
-        {
-            if (other == null)
-            {
-                return;
-            }
-            if (other.PokedexEntryNumber != 0)
-            {
-                PokedexEntryNumber = other.PokedexEntryNumber;
-            }
-            if (other.TimesEncountered != 0)
-            {
-                TimesEncountered = other.TimesEncountered;
-            }
-            if (other.TimesCaptured != 0)
-            {
-                TimesCaptured = other.TimesCaptured;
-            }
-            if (other.EvolutionStonePieces != 0)
-            {
-                EvolutionStonePieces = other.EvolutionStonePieces;
-            }
-            if (other.EvolutionStones != 0)
-            {
-                EvolutionStones = other.EvolutionStones;
-            }
-        }
-
-        public void MergeFrom(pb::CodedInputStream input)
-        {
-            uint tag;
-            while ((tag = input.ReadTag()) != 0)
-            {
-                switch (tag)
-                {
-                    default:
-                        input.SkipLastField();
-                        break;
-                    case 8:
-                        {
-                            PokedexEntryNumber = input.ReadInt32();
-                            break;
-                        }
-                    case 16:
-                        {
-                            TimesEncountered = input.ReadInt32();
-                            break;
-                        }
-                    case 24:
-                        {
-                            TimesCaptured = input.ReadInt32();
-                            break;
-                        }
-                    case 32:
-                        {
-                            EvolutionStonePieces = input.ReadInt32();
-                            break;
-                        }
-                    case 40:
-                        {
-                            EvolutionStones = input.ReadInt32();
-                            break;
-                        }
-                }
-            }
-        }
-
-        public override bool Equals(object other)
-        {
-            return Equals(other as PokedexEntry);
-        }
-
-        public override int GetHashCode()
-        {
-            var hash = 1;
-            if (PokedexEntryNumber != 0) hash ^= PokedexEntryNumber.GetHashCode();
-            if (TimesEncountered != 0) hash ^= TimesEncountered.GetHashCode();
-            if (TimesCaptured != 0) hash ^= TimesCaptured.GetHashCode();
-            if (EvolutionStonePieces != 0) hash ^= EvolutionStonePieces.GetHashCode();
-            if (EvolutionStones != 0) hash ^= EvolutionStones.GetHashCode();
-            return hash;
-        }
-
-        partial void OnConstruction();
-
-        public override string ToString()
-        {
-            return pb::JsonFormatter.ToDiagnosticString(this);
-        }
-    }
-
-    [global::System.Diagnostics.DebuggerNonUserCodeAttribute()]
-    public sealed partial class PlayerStats : pb::IMessage<PlayerStats>
-    {
-        /// <summary>Field number for the "level" field.</summary>
-        public const int LevelFieldNumber = 1;
-
-        /// <summary>Field number for the "experience" field.</summary>
-        public const int ExperienceFieldNumber = 2;
-
-        /// <summary>Field number for the "prev_level_xp" field.</summary>
-        public const int PrevLevelXpFieldNumber = 3;
-
-        /// <summary>Field number for the "next_level_xp" field.</summary>
-        public const int NextLevelXpFieldNumber = 4;
-
-        /// <summary>Field number for the "km_walked" field.</summary>
-        public const int KmWalkedFieldNumber = 5;
-
-        /// <summary>Field number for the "pokemons_encountered" field.</summary>
-        public const int PokemonsEncounteredFieldNumber = 6;
-
-        /// <summary>Field number for the "unique_pokedex_entries" field.</summary>
-        public const int UniquePokedexEntriesFieldNumber = 7;
-
-        /// <summary>Field number for the "pokemons_captured" field.</summary>
-        public const int PokemonsCapturedFieldNumber = 8;
-
-        /// <summary>Field number for the "evolutions" field.</summary>
-        public const int EvolutionsFieldNumber = 9;
-
-        /// <summary>Field number for the "poke_stop_visits" field.</summary>
-        public const int PokeStopVisitsFieldNumber = 10;
-
-        /// <summary>Field number for the "pokeballs_thrown" field.</summary>
-        public const int PokeballsThrownFieldNumber = 11;
-
-        /// <summary>Field number for the "eggs_hatched" field.</summary>
-        public const int EggsHatchedFieldNumber = 12;
-
-        /// <summary>Field number for the "big_magikarp_caught" field.</summary>
-        public const int BigMagikarpCaughtFieldNumber = 13;
-
-        /// <summary>Field number for the "battle_attack_won" field.</summary>
-        public const int BattleAttackWonFieldNumber = 14;
-
-        /// <summary>Field number for the "battle_attack_total" field.</summary>
-        public const int BattleAttackTotalFieldNumber = 15;
-
-        /// <summary>Field number for the "battle_defended_won" field.</summary>
-        public const int BattleDefendedWonFieldNumber = 16;
-
-        /// <summary>Field number for the "battle_training_won" field.</summary>
-        public const int BattleTrainingWonFieldNumber = 17;
-
-        /// <summary>Field number for the "battle_training_total" field.</summary>
-        public const int BattleTrainingTotalFieldNumber = 18;
-
-        /// <summary>Field number for the "prestige_raised_total" field.</summary>
-        public const int PrestigeRaisedTotalFieldNumber = 19;
-
-        /// <summary>Field number for the "prestige_dropped_total" field.</summary>
-        public const int PrestigeDroppedTotalFieldNumber = 20;
-
-        /// <summary>Field number for the "pokemon_deployed" field.</summary>
-        public const int PokemonDeployedFieldNumber = 21;
-
-        /// <summary>Field number for the "pokemon_caught_by_type" field.</summary>
-        public const int PokemonCaughtByTypeFieldNumber = 22;
-
-        /// <summary>Field number for the "small_rattata_caught" field.</summary>
-        public const int SmallRattataCaughtFieldNumber = 23;
-
-        private static readonly pb::MessageParser<PlayerStats> _parser =
-            new pb::MessageParser<PlayerStats>(() => new PlayerStats());
-
-        private int battleAttackTotal_;
-        private int battleAttackWon_;
-        private int battleDefendedWon_;
-        private int battleTrainingTotal_;
-        private int battleTrainingWon_;
-        private int bigMagikarpCaught_;
-        private int eggsHatched_;
-        private int evolutions_;
-        private long experience_;
-        private float kmWalked_;
-        private int level_;
-        private long nextLevelXp_;
-        private int pokeballsThrown_;
-        private pb::ByteString pokemonCaughtByType_ = pb::ByteString.Empty;
-        private int pokemonDeployed_;
-        private int pokemonsCaptured_;
-        private int pokemonsEncountered_;
-        private int pokeStopVisits_;
-        private int prestigeDroppedTotal_;
-        private int prestigeRaisedTotal_;
-        private long prevLevelXp_;
-        private int smallRattataCaught_;
-        private int uniquePokedexEntries_;
-
-        public PlayerStats()
-        {
-            OnConstruction();
-        }
-
-        public PlayerStats(PlayerStats other) : this()
-        {
-            level_ = other.level_;
-            experience_ = other.experience_;
-            prevLevelXp_ = other.prevLevelXp_;
-            nextLevelXp_ = other.nextLevelXp_;
-            kmWalked_ = other.kmWalked_;
-            pokemonsEncountered_ = other.pokemonsEncountered_;
-            uniquePokedexEntries_ = other.uniquePokedexEntries_;
-            pokemonsCaptured_ = other.pokemonsCaptured_;
-            evolutions_ = other.evolutions_;
-            pokeStopVisits_ = other.pokeStopVisits_;
-            pokeballsThrown_ = other.pokeballsThrown_;
-            eggsHatched_ = other.eggsHatched_;
-            bigMagikarpCaught_ = other.bigMagikarpCaught_;
-            battleAttackWon_ = other.battleAttackWon_;
-            battleAttackTotal_ = other.battleAttackTotal_;
-            battleDefendedWon_ = other.battleDefendedWon_;
-            battleTrainingWon_ = other.battleTrainingWon_;
-            battleTrainingTotal_ = other.battleTrainingTotal_;
-            prestigeRaisedTotal_ = other.prestigeRaisedTotal_;
-            prestigeDroppedTotal_ = other.prestigeDroppedTotal_;
-            pokemonDeployed_ = other.pokemonDeployed_;
-            pokemonCaughtByType_ = other.pokemonCaughtByType_;
-            smallRattataCaught_ = other.smallRattataCaught_;
-        }
-
-        public static pb::MessageParser<PlayerStats> Parser
-        {
-            get { return _parser; }
-        }
-
-        public static pbr::MessageDescriptor Descriptor
-        {
-            get { return global::PokemonGo.RocketAPI.GeneratedCode.PayloadsReflection.Descriptor.MessageTypes[14]; }
-        }
-
-        public int Level
-        {
-            get { return level_; }
-            set { level_ = value; }
-        }
-
-        public long Experience
-        {
-            get { return experience_; }
-            set { experience_ = value; }
-        }
-
-        public long PrevLevelXp
-        {
-            get { return prevLevelXp_; }
-            set { prevLevelXp_ = value; }
-        }
-
-        public long NextLevelXp
-        {
-            get { return nextLevelXp_; }
-            set { nextLevelXp_ = value; }
-        }
-
-        public float KmWalked
-        {
-            get { return kmWalked_; }
-            set { kmWalked_ = value; }
-        }
-
-        public int PokemonsEncountered
-        {
-            get { return pokemonsEncountered_; }
-            set { pokemonsEncountered_ = value; }
-        }
-
-        public int UniquePokedexEntries
-        {
-            get { return uniquePokedexEntries_; }
-            set { uniquePokedexEntries_ = value; }
-        }
-
-        public int PokemonsCaptured
-        {
-            get { return pokemonsCaptured_; }
-            set { pokemonsCaptured_ = value; }
-        }
-
-        public int Evolutions
-        {
-            get { return evolutions_; }
-            set { evolutions_ = value; }
-        }
-
-        public int PokeStopVisits
-        {
-            get { return pokeStopVisits_; }
-            set { pokeStopVisits_ = value; }
-        }
-
-        public int PokeballsThrown
-        {
-            get { return pokeballsThrown_; }
-            set { pokeballsThrown_ = value; }
-        }
-
-        public int EggsHatched
-        {
-            get { return eggsHatched_; }
-            set { eggsHatched_ = value; }
-        }
-
-        public int BigMagikarpCaught
-        {
-            get { return bigMagikarpCaught_; }
-            set { bigMagikarpCaught_ = value; }
-        }
-
-        public int BattleAttackWon
-        {
-            get { return battleAttackWon_; }
-            set { battleAttackWon_ = value; }
-        }
-
-        public int BattleAttackTotal
-        {
-            get { return battleAttackTotal_; }
-            set { battleAttackTotal_ = value; }
-        }
-
-        public int BattleDefendedWon
-        {
-            get { return battleDefendedWon_; }
-            set { battleDefendedWon_ = value; }
-        }
-
-        public int BattleTrainingWon
-        {
-            get { return battleTrainingWon_; }
-            set { battleTrainingWon_ = value; }
-        }
-
-        public int BattleTrainingTotal
-        {
-            get { return battleTrainingTotal_; }
-            set { battleTrainingTotal_ = value; }
-        }
-
-        public int PrestigeRaisedTotal
-        {
-            get { return prestigeRaisedTotal_; }
-            set { prestigeRaisedTotal_ = value; }
-        }
-
-        public int PrestigeDroppedTotal
-        {
-            get { return prestigeDroppedTotal_; }
-            set { prestigeDroppedTotal_ = value; }
-        }
-
-        public int PokemonDeployed
-        {
-            get { return pokemonDeployed_; }
-            set { pokemonDeployed_ = value; }
-        }
-
-        /// <summary>
-        ///     TODO: repeated PokemonType ??
-        /// </summary>
-        public pb::ByteString PokemonCaughtByType
-        {
-            get { return pokemonCaughtByType_; }
-            set { pokemonCaughtByType_ = pb::ProtoPreconditions.CheckNotNull(value, "value"); }
-        }
-
-        public int SmallRattataCaught
-        {
-            get { return smallRattataCaught_; }
-            set { smallRattataCaught_ = value; }
-        }
-
-        pbr::MessageDescriptor pb::IMessage.Descriptor
-        {
-            get { return Descriptor; }
-        }
-
-        public PlayerStats Clone()
-        {
-            return new PlayerStats(this);
-        }
-
-        public bool Equals(PlayerStats other)
-        {
-            if (ReferenceEquals(other, null))
-            {
-                return false;
-            }
-            if (ReferenceEquals(other, this))
-            {
-                return true;
-            }
-            if (Level != other.Level) return false;
-            if (Experience != other.Experience) return false;
-            if (PrevLevelXp != other.PrevLevelXp) return false;
-            if (NextLevelXp != other.NextLevelXp) return false;
-            if (KmWalked != other.KmWalked) return false;
-            if (PokemonsEncountered != other.PokemonsEncountered) return false;
-            if (UniquePokedexEntries != other.UniquePokedexEntries) return false;
-            if (PokemonsCaptured != other.PokemonsCaptured) return false;
-            if (Evolutions != other.Evolutions) return false;
-            if (PokeStopVisits != other.PokeStopVisits) return false;
-            if (PokeballsThrown != other.PokeballsThrown) return false;
-            if (EggsHatched != other.EggsHatched) return false;
-            if (BigMagikarpCaught != other.BigMagikarpCaught) return false;
-            if (BattleAttackWon != other.BattleAttackWon) return false;
-            if (BattleAttackTotal != other.BattleAttackTotal) return false;
-            if (BattleDefendedWon != other.BattleDefendedWon) return false;
-            if (BattleTrainingWon != other.BattleTrainingWon) return false;
-            if (BattleTrainingTotal != other.BattleTrainingTotal) return false;
-            if (PrestigeRaisedTotal != other.PrestigeRaisedTotal) return false;
-            if (PrestigeDroppedTotal != other.PrestigeDroppedTotal) return false;
-            if (PokemonDeployed != other.PokemonDeployed) return false;
-            if (PokemonCaughtByType != other.PokemonCaughtByType) return false;
-            if (SmallRattataCaught != other.SmallRattataCaught) return false;
-            return true;
-        }
-
-        public void WriteTo(pb::CodedOutputStream output)
-        {
-            if (Level != 0)
-            {
-                output.WriteRawTag(8);
-                output.WriteInt32(Level);
-            }
-            if (Experience != 0L)
-            {
-                output.WriteRawTag(16);
-                output.WriteInt64(Experience);
-            }
-            if (PrevLevelXp != 0L)
-            {
-                output.WriteRawTag(24);
-                output.WriteInt64(PrevLevelXp);
-            }
-            if (NextLevelXp != 0L)
-            {
-                output.WriteRawTag(32);
-                output.WriteInt64(NextLevelXp);
-            }
-            if (KmWalked != 0F)
-            {
-                output.WriteRawTag(45);
-                output.WriteFloat(KmWalked);
-            }
-            if (PokemonsEncountered != 0)
-            {
-                output.WriteRawTag(48);
-                output.WriteInt32(PokemonsEncountered);
-            }
-            if (UniquePokedexEntries != 0)
-            {
-                output.WriteRawTag(56);
-                output.WriteInt32(UniquePokedexEntries);
-            }
-            if (PokemonsCaptured != 0)
-            {
-                output.WriteRawTag(64);
-                output.WriteInt32(PokemonsCaptured);
-            }
-            if (Evolutions != 0)
-            {
-                output.WriteRawTag(72);
-                output.WriteInt32(Evolutions);
-            }
-            if (PokeStopVisits != 0)
-            {
-                output.WriteRawTag(80);
-                output.WriteInt32(PokeStopVisits);
-            }
-            if (PokeballsThrown != 0)
-            {
-                output.WriteRawTag(88);
-                output.WriteInt32(PokeballsThrown);
-            }
-            if (EggsHatched != 0)
-            {
-                output.WriteRawTag(96);
-                output.WriteInt32(EggsHatched);
-            }
-            if (BigMagikarpCaught != 0)
-            {
-                output.WriteRawTag(104);
-                output.WriteInt32(BigMagikarpCaught);
-            }
-            if (BattleAttackWon != 0)
-            {
-                output.WriteRawTag(112);
-                output.WriteInt32(BattleAttackWon);
-            }
-            if (BattleAttackTotal != 0)
-            {
-                output.WriteRawTag(120);
-                output.WriteInt32(BattleAttackTotal);
-            }
-            if (BattleDefendedWon != 0)
-            {
-                output.WriteRawTag(128, 1);
-                output.WriteInt32(BattleDefendedWon);
-            }
-            if (BattleTrainingWon != 0)
-            {
-                output.WriteRawTag(136, 1);
-                output.WriteInt32(BattleTrainingWon);
-            }
-            if (BattleTrainingTotal != 0)
-            {
-                output.WriteRawTag(144, 1);
-                output.WriteInt32(BattleTrainingTotal);
-            }
-            if (PrestigeRaisedTotal != 0)
-            {
-                output.WriteRawTag(152, 1);
-                output.WriteInt32(PrestigeRaisedTotal);
-            }
-            if (PrestigeDroppedTotal != 0)
-            {
-                output.WriteRawTag(160, 1);
-                output.WriteInt32(PrestigeDroppedTotal);
-            }
-            if (PokemonDeployed != 0)
-            {
-                output.WriteRawTag(168, 1);
-                output.WriteInt32(PokemonDeployed);
-            }
-            if (PokemonCaughtByType.Length != 0)
-            {
-                output.WriteRawTag(178, 1);
-                output.WriteBytes(PokemonCaughtByType);
-            }
-            if (SmallRattataCaught != 0)
-            {
-                output.WriteRawTag(184, 1);
-                output.WriteInt32(SmallRattataCaught);
-            }
-        }
-
-        public int CalculateSize()
-        {
-            var size = 0;
-            if (Level != 0)
-            {
-                size += 1 + pb::CodedOutputStream.ComputeInt32Size(Level);
-            }
-            if (Experience != 0L)
-            {
-                size += 1 + pb::CodedOutputStream.ComputeInt64Size(Experience);
-            }
-            if (PrevLevelXp != 0L)
-            {
-                size += 1 + pb::CodedOutputStream.ComputeInt64Size(PrevLevelXp);
-            }
-            if (NextLevelXp != 0L)
-            {
-                size += 1 + pb::CodedOutputStream.ComputeInt64Size(NextLevelXp);
-            }
-            if (KmWalked != 0F)
-            {
-                size += 1 + 4;
-            }
-            if (PokemonsEncountered != 0)
-            {
-                size += 1 + pb::CodedOutputStream.ComputeInt32Size(PokemonsEncountered);
-            }
-            if (UniquePokedexEntries != 0)
-            {
-                size += 1 + pb::CodedOutputStream.ComputeInt32Size(UniquePokedexEntries);
-            }
-            if (PokemonsCaptured != 0)
-            {
-                size += 1 + pb::CodedOutputStream.ComputeInt32Size(PokemonsCaptured);
-            }
-            if (Evolutions != 0)
-            {
-                size += 1 + pb::CodedOutputStream.ComputeInt32Size(Evolutions);
-            }
-            if (PokeStopVisits != 0)
-            {
-                size += 1 + pb::CodedOutputStream.ComputeInt32Size(PokeStopVisits);
-            }
-            if (PokeballsThrown != 0)
-            {
-                size += 1 + pb::CodedOutputStream.ComputeInt32Size(PokeballsThrown);
-            }
-            if (EggsHatched != 0)
-            {
-                size += 1 + pb::CodedOutputStream.ComputeInt32Size(EggsHatched);
-            }
-            if (BigMagikarpCaught != 0)
-            {
-                size += 1 + pb::CodedOutputStream.ComputeInt32Size(BigMagikarpCaught);
-            }
-            if (BattleAttackWon != 0)
-            {
-                size += 1 + pb::CodedOutputStream.ComputeInt32Size(BattleAttackWon);
-            }
-            if (BattleAttackTotal != 0)
-            {
-                size += 1 + pb::CodedOutputStream.ComputeInt32Size(BattleAttackTotal);
-            }
-            if (BattleDefendedWon != 0)
-            {
-                size += 2 + pb::CodedOutputStream.ComputeInt32Size(BattleDefendedWon);
-            }
-            if (BattleTrainingWon != 0)
-            {
-                size += 2 + pb::CodedOutputStream.ComputeInt32Size(BattleTrainingWon);
-            }
-            if (BattleTrainingTotal != 0)
-            {
-                size += 2 + pb::CodedOutputStream.ComputeInt32Size(BattleTrainingTotal);
-            }
-            if (PrestigeRaisedTotal != 0)
-            {
-                size += 2 + pb::CodedOutputStream.ComputeInt32Size(PrestigeRaisedTotal);
-            }
-            if (PrestigeDroppedTotal != 0)
-            {
-                size += 2 + pb::CodedOutputStream.ComputeInt32Size(PrestigeDroppedTotal);
-            }
-            if (PokemonDeployed != 0)
-            {
-                size += 2 + pb::CodedOutputStream.ComputeInt32Size(PokemonDeployed);
-            }
-            if (PokemonCaughtByType.Length != 0)
-            {
-                size += 2 + pb::CodedOutputStream.ComputeBytesSize(PokemonCaughtByType);
-            }
-            if (SmallRattataCaught != 0)
-            {
-                size += 2 + pb::CodedOutputStream.ComputeInt32Size(SmallRattataCaught);
-            }
-            return size;
-        }
-
-        public void MergeFrom(PlayerStats other)
-        {
-            if (other == null)
-            {
-                return;
-            }
-            if (other.Level != 0)
-            {
-                Level = other.Level;
-            }
-            if (other.Experience != 0L)
-            {
-                Experience = other.Experience;
-            }
-            if (other.PrevLevelXp != 0L)
-            {
-                PrevLevelXp = other.PrevLevelXp;
-            }
-            if (other.NextLevelXp != 0L)
-            {
-                NextLevelXp = other.NextLevelXp;
-            }
-            if (other.KmWalked != 0F)
-            {
-                KmWalked = other.KmWalked;
-            }
-            if (other.PokemonsEncountered != 0)
-            {
-                PokemonsEncountered = other.PokemonsEncountered;
-            }
-            if (other.UniquePokedexEntries != 0)
-            {
-                UniquePokedexEntries = other.UniquePokedexEntries;
-            }
-            if (other.PokemonsCaptured != 0)
-            {
-                PokemonsCaptured = other.PokemonsCaptured;
-            }
-            if (other.Evolutions != 0)
-            {
-                Evolutions = other.Evolutions;
-            }
-            if (other.PokeStopVisits != 0)
-            {
-                PokeStopVisits = other.PokeStopVisits;
-            }
-            if (other.PokeballsThrown != 0)
-            {
-                PokeballsThrown = other.PokeballsThrown;
-            }
-            if (other.EggsHatched != 0)
-            {
-                EggsHatched = other.EggsHatched;
-            }
-            if (other.BigMagikarpCaught != 0)
-            {
-                BigMagikarpCaught = other.BigMagikarpCaught;
-            }
-            if (other.BattleAttackWon != 0)
-            {
-                BattleAttackWon = other.BattleAttackWon;
-            }
-            if (other.BattleAttackTotal != 0)
-            {
-                BattleAttackTotal = other.BattleAttackTotal;
-            }
-            if (other.BattleDefendedWon != 0)
-            {
-                BattleDefendedWon = other.BattleDefendedWon;
-            }
-            if (other.BattleTrainingWon != 0)
-            {
-                BattleTrainingWon = other.BattleTrainingWon;
-            }
-            if (other.BattleTrainingTotal != 0)
-            {
-                BattleTrainingTotal = other.BattleTrainingTotal;
-            }
-            if (other.PrestigeRaisedTotal != 0)
-            {
-                PrestigeRaisedTotal = other.PrestigeRaisedTotal;
-            }
-            if (other.PrestigeDroppedTotal != 0)
-            {
-                PrestigeDroppedTotal = other.PrestigeDroppedTotal;
-            }
-            if (other.PokemonDeployed != 0)
-            {
-                PokemonDeployed = other.PokemonDeployed;
-            }
-            if (other.PokemonCaughtByType.Length != 0)
-            {
-                PokemonCaughtByType = other.PokemonCaughtByType;
-            }
-            if (other.SmallRattataCaught != 0)
-            {
-                SmallRattataCaught = other.SmallRattataCaught;
-            }
-        }
-
-        public void MergeFrom(pb::CodedInputStream input)
-        {
-            uint tag;
-            while ((tag = input.ReadTag()) != 0)
-            {
-                switch (tag)
-                {
-                    default:
-                        input.SkipLastField();
-                        break;
-                    case 8:
-                        {
-                            Level = input.ReadInt32();
-                            break;
-                        }
-                    case 16:
-                        {
-                            Experience = input.ReadInt64();
-                            break;
-                        }
-                    case 24:
-                        {
-                            PrevLevelXp = input.ReadInt64();
-                            break;
-                        }
-                    case 32:
-                        {
-                            NextLevelXp = input.ReadInt64();
-                            break;
-                        }
-                    case 45:
-                        {
-                            KmWalked = input.ReadFloat();
-                            break;
-                        }
-                    case 48:
-                        {
-                            PokemonsEncountered = input.ReadInt32();
-                            break;
-                        }
-                    case 56:
-                        {
-                            UniquePokedexEntries = input.ReadInt32();
-                            break;
-                        }
-                    case 64:
-                        {
-                            PokemonsCaptured = input.ReadInt32();
-                            break;
-                        }
-                    case 72:
-                        {
-                            Evolutions = input.ReadInt32();
-                            break;
-                        }
-                    case 80:
-                        {
-                            PokeStopVisits = input.ReadInt32();
-                            break;
-                        }
-                    case 88:
-                        {
-                            PokeballsThrown = input.ReadInt32();
-                            break;
-                        }
-                    case 96:
-                        {
-                            EggsHatched = input.ReadInt32();
-                            break;
-                        }
-                    case 104:
-                        {
-                            BigMagikarpCaught = input.ReadInt32();
-                            break;
-                        }
-                    case 112:
-                        {
-                            BattleAttackWon = input.ReadInt32();
-                            break;
-                        }
-                    case 120:
-                        {
-                            BattleAttackTotal = input.ReadInt32();
-                            break;
-                        }
-                    case 128:
-                        {
-                            BattleDefendedWon = input.ReadInt32();
-                            break;
-                        }
-                    case 136:
-                        {
-                            BattleTrainingWon = input.ReadInt32();
-                            break;
-                        }
-                    case 144:
-                        {
-                            BattleTrainingTotal = input.ReadInt32();
-                            break;
-                        }
-                    case 152:
-                        {
-                            PrestigeRaisedTotal = input.ReadInt32();
-                            break;
-                        }
-                    case 160:
-                        {
-                            PrestigeDroppedTotal = input.ReadInt32();
-                            break;
-                        }
-                    case 168:
-                        {
-                            PokemonDeployed = input.ReadInt32();
-                            break;
-                        }
-                    case 178:
-                        {
-                            PokemonCaughtByType = input.ReadBytes();
-                            break;
-                        }
-                    case 184:
-                        {
-                            SmallRattataCaught = input.ReadInt32();
-                            break;
-                        }
-                }
-            }
-        }
-
-        public override bool Equals(object other)
-        {
-            return Equals(other as PlayerStats);
-        }
-
-        public override int GetHashCode()
-        {
-            var hash = 1;
-            if (Level != 0) hash ^= Level.GetHashCode();
-            if (Experience != 0L) hash ^= Experience.GetHashCode();
-            if (PrevLevelXp != 0L) hash ^= PrevLevelXp.GetHashCode();
-            if (NextLevelXp != 0L) hash ^= NextLevelXp.GetHashCode();
-            if (KmWalked != 0F) hash ^= KmWalked.GetHashCode();
-            if (PokemonsEncountered != 0) hash ^= PokemonsEncountered.GetHashCode();
-            if (UniquePokedexEntries != 0) hash ^= UniquePokedexEntries.GetHashCode();
-            if (PokemonsCaptured != 0) hash ^= PokemonsCaptured.GetHashCode();
-            if (Evolutions != 0) hash ^= Evolutions.GetHashCode();
-            if (PokeStopVisits != 0) hash ^= PokeStopVisits.GetHashCode();
-            if (PokeballsThrown != 0) hash ^= PokeballsThrown.GetHashCode();
-            if (EggsHatched != 0) hash ^= EggsHatched.GetHashCode();
-            if (BigMagikarpCaught != 0) hash ^= BigMagikarpCaught.GetHashCode();
-            if (BattleAttackWon != 0) hash ^= BattleAttackWon.GetHashCode();
-            if (BattleAttackTotal != 0) hash ^= BattleAttackTotal.GetHashCode();
-            if (BattleDefendedWon != 0) hash ^= BattleDefendedWon.GetHashCode();
-            if (BattleTrainingWon != 0) hash ^= BattleTrainingWon.GetHashCode();
-            if (BattleTrainingTotal != 0) hash ^= BattleTrainingTotal.GetHashCode();
-            if (PrestigeRaisedTotal != 0) hash ^= PrestigeRaisedTotal.GetHashCode();
-            if (PrestigeDroppedTotal != 0) hash ^= PrestigeDroppedTotal.GetHashCode();
-            if (PokemonDeployed != 0) hash ^= PokemonDeployed.GetHashCode();
-            if (PokemonCaughtByType.Length != 0) hash ^= PokemonCaughtByType.GetHashCode();
-            if (SmallRattataCaught != 0) hash ^= SmallRattataCaught.GetHashCode();
-            return hash;
-        }
-
-        partial void OnConstruction();
-
-        public override string ToString()
-        {
-            return pb::JsonFormatter.ToDiagnosticString(this);
-        }
-    }
-
-    [global::System.Diagnostics.DebuggerNonUserCodeAttribute()]
-    public sealed partial class PlayerCurrency : pb::IMessage<PlayerCurrency>
-    {
-        /// <summary>Field number for the "gems" field.</summary>
-        public const int GemsFieldNumber = 1;
-
-        private static readonly pb::MessageParser<PlayerCurrency> _parser =
-            new pb::MessageParser<PlayerCurrency>(() => new PlayerCurrency());
-
-        private int gems_;
-
-        public PlayerCurrency()
-        {
-            OnConstruction();
-        }
-
-        public PlayerCurrency(PlayerCurrency other) : this()
-        {
-            gems_ = other.gems_;
-        }
-
-        public static pb::MessageParser<PlayerCurrency> Parser
-        {
-            get { return _parser; }
-        }
-
-        public static pbr::MessageDescriptor Descriptor
-        {
-            get { return global::PokemonGo.RocketAPI.GeneratedCode.PayloadsReflection.Descriptor.MessageTypes[15]; }
-        }
-
-        public int Gems
-        {
-            get { return gems_; }
-            set { gems_ = value; }
-        }
-
-        pbr::MessageDescriptor pb::IMessage.Descriptor
-        {
-            get { return Descriptor; }
-        }
-
-        public PlayerCurrency Clone()
-        {
-            return new PlayerCurrency(this);
-        }
-
-        public bool Equals(PlayerCurrency other)
-        {
-            if (ReferenceEquals(other, null))
-            {
-                return false;
-            }
-            if (ReferenceEquals(other, this))
-            {
-                return true;
-            }
-            if (Gems != other.Gems) return false;
-            return true;
-        }
-
-        public void WriteTo(pb::CodedOutputStream output)
-        {
-            if (Gems != 0)
-            {
-                output.WriteRawTag(8);
-                output.WriteInt32(Gems);
-            }
-        }
-
-        public int CalculateSize()
-        {
-            var size = 0;
-            if (Gems != 0)
-            {
-                size += 1 + pb::CodedOutputStream.ComputeInt32Size(Gems);
-            }
-            return size;
-        }
-
-        public void MergeFrom(PlayerCurrency other)
-        {
-            if (other == null)
-            {
-                return;
-            }
-            if (other.Gems != 0)
-            {
-                Gems = other.Gems;
-            }
-        }
-
-        public void MergeFrom(pb::CodedInputStream input)
-        {
-            uint tag;
-            while ((tag = input.ReadTag()) != 0)
-            {
-                switch (tag)
-                {
-                    default:
-                        input.SkipLastField();
-                        break;
-                    case 8:
-                        {
-                            Gems = input.ReadInt32();
-                            break;
-                        }
-                }
-            }
-        }
-
-        public override bool Equals(object other)
-        {
-            return Equals(other as PlayerCurrency);
-        }
-
-        public override int GetHashCode()
-        {
-            var hash = 1;
-            if (Gems != 0) hash ^= Gems.GetHashCode();
-            return hash;
-        }
-
-        partial void OnConstruction();
-
-        public override string ToString()
-        {
-            return pb::JsonFormatter.ToDiagnosticString(this);
-        }
-    }
-
-    [global::System.Diagnostics.DebuggerNonUserCodeAttribute()]
-    public sealed partial class PlayerCamera : pb::IMessage<PlayerCamera>
-    {
-        /// <summary>Field number for the "is_default_camera" field.</summary>
-        public const int IsDefaultCameraFieldNumber = 1;
-
-        private static readonly pb::MessageParser<PlayerCamera> _parser =
-            new pb::MessageParser<PlayerCamera>(() => new PlayerCamera());
-
-        private bool isDefaultCamera_;
-
-        public PlayerCamera()
-        {
-            OnConstruction();
-        }
-
-        public PlayerCamera(PlayerCamera other) : this()
-        {
-            isDefaultCamera_ = other.isDefaultCamera_;
-        }
-
-        public static pb::MessageParser<PlayerCamera> Parser
-        {
-            get { return _parser; }
-        }
-
-        public static pbr::MessageDescriptor Descriptor
-        {
-            get { return global::PokemonGo.RocketAPI.GeneratedCode.PayloadsReflection.Descriptor.MessageTypes[16]; }
-        }
-
-        public bool IsDefaultCamera
-        {
-            get { return isDefaultCamera_; }
-            set { isDefaultCamera_ = value; }
-        }
-
-        pbr::MessageDescriptor pb::IMessage.Descriptor
-        {
-            get { return Descriptor; }
-        }
-
-        public PlayerCamera Clone()
-        {
-            return new PlayerCamera(this);
-        }
-
-        public bool Equals(PlayerCamera other)
-        {
-            if (ReferenceEquals(other, null))
-            {
-                return false;
-            }
-            if (ReferenceEquals(other, this))
-            {
-                return true;
-            }
-            if (IsDefaultCamera != other.IsDefaultCamera) return false;
-            return true;
-        }
-
-        public void WriteTo(pb::CodedOutputStream output)
-        {
-            if (IsDefaultCamera != false)
-            {
-                output.WriteRawTag(8);
-                output.WriteBool(IsDefaultCamera);
-            }
-        }
-
-        public int CalculateSize()
-        {
-            var size = 0;
-            if (IsDefaultCamera != false)
-            {
-                size += 1 + 1;
-            }
-            return size;
-        }
-
-        public void MergeFrom(PlayerCamera other)
-        {
-            if (other == null)
-            {
-                return;
-            }
-            if (other.IsDefaultCamera != false)
-            {
-                IsDefaultCamera = other.IsDefaultCamera;
-            }
-        }
-
-        public void MergeFrom(pb::CodedInputStream input)
-        {
-            uint tag;
-            while ((tag = input.ReadTag()) != 0)
-            {
-                switch (tag)
-                {
-                    default:
-                        input.SkipLastField();
-                        break;
-                    case 8:
-                        {
-                            IsDefaultCamera = input.ReadBool();
-                            break;
-                        }
-                }
-            }
-        }
-
-        public override bool Equals(object other)
-        {
-            return Equals(other as PlayerCamera);
-        }
-
-        public override int GetHashCode()
-        {
-            var hash = 1;
-            if (IsDefaultCamera != false) hash ^= IsDefaultCamera.GetHashCode();
-            return hash;
-        }
-
-        partial void OnConstruction();
-
-        public override string ToString()
-        {
-            return pb::JsonFormatter.ToDiagnosticString(this);
-        }
-    }
-
-    [global::System.Diagnostics.DebuggerNonUserCodeAttribute()]
-    public sealed partial class InventoryUpgrades : pb::IMessage<InventoryUpgrades>
-    {
-        /// <summary>Field number for the "inventory_upgrades" field.</summary>
-        public const int InventoryUpgrades_FieldNumber = 1;
-
-        private static readonly pb::MessageParser<InventoryUpgrades> _parser =
-            new pb::MessageParser<InventoryUpgrades>(() => new InventoryUpgrades());
-
-        private static readonly pb::FieldCodec<global::PokemonGo.RocketAPI.GeneratedCode.InventoryUpgrade>
-            _repeated_inventoryUpgrades_codec
-                = pb::FieldCodec.ForMessage(10, global::PokemonGo.RocketAPI.GeneratedCode.InventoryUpgrade.Parser);
-
-        private readonly pbc::RepeatedField<global::PokemonGo.RocketAPI.GeneratedCode.InventoryUpgrade>
-            inventoryUpgrades_ = new pbc::RepeatedField<global::PokemonGo.RocketAPI.GeneratedCode.InventoryUpgrade>();
-
-        public InventoryUpgrades()
-        {
-            OnConstruction();
-        }
-
-        public InventoryUpgrades(InventoryUpgrades other) : this()
-        {
-            inventoryUpgrades_ = other.inventoryUpgrades_.Clone();
-        }
-
-        public static pb::MessageParser<InventoryUpgrades> Parser
-        {
-            get { return _parser; }
-        }
-
-        public static pbr::MessageDescriptor Descriptor
-        {
-            get { return global::PokemonGo.RocketAPI.GeneratedCode.PayloadsReflection.Descriptor.MessageTypes[17]; }
-        }
-
-        public pbc::RepeatedField<global::PokemonGo.RocketAPI.GeneratedCode.InventoryUpgrade> InventoryUpgrades_
-        {
-            get { return inventoryUpgrades_; }
-        }
-
-        pbr::MessageDescriptor pb::IMessage.Descriptor
-        {
-            get { return Descriptor; }
-        }
-
-        public InventoryUpgrades Clone()
-        {
-            return new InventoryUpgrades(this);
-        }
-
-        public bool Equals(InventoryUpgrades other)
-        {
-            if (ReferenceEquals(other, null))
-            {
-                return false;
-            }
-            if (ReferenceEquals(other, this))
-            {
-                return true;
-            }
-            if (!inventoryUpgrades_.Equals(other.inventoryUpgrades_)) return false;
-            return true;
-        }
-
-        public void WriteTo(pb::CodedOutputStream output)
-        {
-            inventoryUpgrades_.WriteTo(output, _repeated_inventoryUpgrades_codec);
-        }
-
-        public int CalculateSize()
-        {
-            var size = 0;
-            size += inventoryUpgrades_.CalculateSize(_repeated_inventoryUpgrades_codec);
-            return size;
-        }
-
-        public void MergeFrom(InventoryUpgrades other)
-        {
-            if (other == null)
-            {
-                return;
-            }
-            inventoryUpgrades_.Add(other.inventoryUpgrades_);
-        }
-
-        public void MergeFrom(pb::CodedInputStream input)
-        {
-            uint tag;
-            while ((tag = input.ReadTag()) != 0)
-            {
-                switch (tag)
-                {
-                    default:
-                        input.SkipLastField();
-                        break;
-                    case 10:
-                        {
-                            inventoryUpgrades_.AddEntriesFrom(input, _repeated_inventoryUpgrades_codec);
-                            break;
-                        }
-                }
-            }
-        }
-
-        public override bool Equals(object other)
-        {
-            return Equals(other as InventoryUpgrades);
-        }
-
-        public override int GetHashCode()
-        {
-            var hash = 1;
-            hash ^= inventoryUpgrades_.GetHashCode();
-            return hash;
-        }
-
-        partial void OnConstruction();
-
-        public override string ToString()
-        {
-            return pb::JsonFormatter.ToDiagnosticString(this);
-        }
-    }
-
-    [global::System.Diagnostics.DebuggerNonUserCodeAttribute()]
-    public sealed partial class InventoryUpgrade : pb::IMessage<InventoryUpgrade>
-    {
-        /// <summary>Field number for the "item" field.</summary>
-        public const int ItemFieldNumber = 1;
-
-        /// <summary>Field number for the "upgrade_type" field.</summary>
-        public const int UpgradeTypeFieldNumber = 2;
-
-        /// <summary>Field number for the "additional_storage" field.</summary>
-        public const int AdditionalStorageFieldNumber = 3;
-
-        private static readonly pb::MessageParser<InventoryUpgrade> _parser =
-            new pb::MessageParser<InventoryUpgrade>(() => new InventoryUpgrade());
-
-        private int additionalStorage_;
-        private global::PokemonGo.RocketAPI.GeneratedCode.ItemType item_ = 0;
-        private global::PokemonGo.RocketAPI.GeneratedCode.InventoryUpgradeType upgradeType_ = 0;
-
-        public InventoryUpgrade()
-        {
-            OnConstruction();
-        }
-
-        public InventoryUpgrade(InventoryUpgrade other) : this()
-        {
-            item_ = other.item_;
-            upgradeType_ = other.upgradeType_;
-            additionalStorage_ = other.additionalStorage_;
-        }
-
-        public static pb::MessageParser<InventoryUpgrade> Parser
-        {
-            get { return _parser; }
-        }
-
-        public static pbr::MessageDescriptor Descriptor
-        {
-            get { return global::PokemonGo.RocketAPI.GeneratedCode.PayloadsReflection.Descriptor.MessageTypes[18]; }
-        }
-
-        public global::PokemonGo.RocketAPI.GeneratedCode.ItemType Item
-        {
-            get { return item_; }
-            set { item_ = value; }
-        }
-
-        public global::PokemonGo.RocketAPI.GeneratedCode.InventoryUpgradeType UpgradeType
-        {
-            get { return upgradeType_; }
-            set { upgradeType_ = value; }
-        }
-
-        public int AdditionalStorage
-        {
-            get { return additionalStorage_; }
-            set { additionalStorage_ = value; }
-        }
-
-        pbr::MessageDescriptor pb::IMessage.Descriptor
-        {
-            get { return Descriptor; }
-        }
-
-        public InventoryUpgrade Clone()
-        {
-            return new InventoryUpgrade(this);
-        }
-
-        public bool Equals(InventoryUpgrade other)
-        {
-            if (ReferenceEquals(other, null))
-            {
-                return false;
-            }
-            if (ReferenceEquals(other, this))
-            {
-                return true;
-            }
-            if (Item != other.Item) return false;
-            if (UpgradeType != other.UpgradeType) return false;
-            if (AdditionalStorage != other.AdditionalStorage) return false;
-            return true;
-        }
-
-        public void WriteTo(pb::CodedOutputStream output)
-        {
-            if (Item != 0)
-            {
-                output.WriteRawTag(8);
-                output.WriteEnum((int)Item);
-            }
-            if (UpgradeType != 0)
-            {
-                output.WriteRawTag(16);
-                output.WriteEnum((int)UpgradeType);
-            }
-            if (AdditionalStorage != 0)
-            {
-                output.WriteRawTag(24);
-                output.WriteInt32(AdditionalStorage);
-            }
-        }
-
-        public int CalculateSize()
-        {
-            var size = 0;
-            if (Item != 0)
-            {
-                size += 1 + pb::CodedOutputStream.ComputeEnumSize((int)Item);
-            }
-            if (UpgradeType != 0)
-            {
-                size += 1 + pb::CodedOutputStream.ComputeEnumSize((int)UpgradeType);
-            }
-            if (AdditionalStorage != 0)
-            {
-                size += 1 + pb::CodedOutputStream.ComputeInt32Size(AdditionalStorage);
-            }
-            return size;
-        }
-
-        public void MergeFrom(InventoryUpgrade other)
-        {
-            if (other == null)
-            {
-                return;
-            }
-            if (other.Item != 0)
-            {
-                Item = other.Item;
-            }
-            if (other.UpgradeType != 0)
-            {
-                UpgradeType = other.UpgradeType;
-            }
-            if (other.AdditionalStorage != 0)
-            {
-                AdditionalStorage = other.AdditionalStorage;
-            }
-        }
-
-        public void MergeFrom(pb::CodedInputStream input)
-        {
-            uint tag;
-            while ((tag = input.ReadTag()) != 0)
-            {
-                switch (tag)
-                {
-                    default:
-                        input.SkipLastField();
-                        break;
-                    case 8:
-                        {
-                            item_ = (global::PokemonGo.RocketAPI.GeneratedCode.ItemType)input.ReadEnum();
-                            break;
-                        }
-                    case 16:
-                        {
-                            upgradeType_ = (global::PokemonGo.RocketAPI.GeneratedCode.InventoryUpgradeType)input.ReadEnum();
-                            break;
-                        }
-                    case 24:
-                        {
-                            AdditionalStorage = input.ReadInt32();
-                            break;
-                        }
-                }
-            }
-        }
-
-        public override bool Equals(object other)
-        {
-            return Equals(other as InventoryUpgrade);
-        }
-
-        public override int GetHashCode()
-        {
-            var hash = 1;
-            if (Item != 0) hash ^= Item.GetHashCode();
-            if (UpgradeType != 0) hash ^= UpgradeType.GetHashCode();
-            if (AdditionalStorage != 0) hash ^= AdditionalStorage.GetHashCode();
-            return hash;
-        }
-
-        partial void OnConstruction();
-
-        public override string ToString()
-        {
-            return pb::JsonFormatter.ToDiagnosticString(this);
-        }
-    }
-
-    [global::System.Diagnostics.DebuggerNonUserCodeAttribute()]
-    public sealed partial class AppliedItems : pb::IMessage<AppliedItems>
-    {
-        /// <summary>Field number for the "item" field.</summary>
-        public const int ItemFieldNumber = 4;
-
-        private static readonly pb::MessageParser<AppliedItems> _parser =
-            new pb::MessageParser<AppliedItems>(() => new AppliedItems());
-
-        private global::PokemonGo.RocketAPI.GeneratedCode.AppliedItem item_;
-
-        public AppliedItems()
-        {
-            OnConstruction();
-        }
-
-        public AppliedItems(AppliedItems other) : this()
-        {
-            Item = other.item_ != null ? other.Item.Clone() : null;
-        }
-
-        public static pb::MessageParser<AppliedItems> Parser
-        {
-            get { return _parser; }
-        }
-
-        public static pbr::MessageDescriptor Descriptor
-        {
-            get { return global::PokemonGo.RocketAPI.GeneratedCode.PayloadsReflection.Descriptor.MessageTypes[19]; }
-        }
-
-        public global::PokemonGo.RocketAPI.GeneratedCode.AppliedItem Item
-        {
-            get { return item_; }
-            set { item_ = value; }
-        }
-
-        pbr::MessageDescriptor pb::IMessage.Descriptor
-        {
-            get { return Descriptor; }
-        }
-
-        public AppliedItems Clone()
-        {
-            return new AppliedItems(this);
-        }
-
-        public bool Equals(AppliedItems other)
-        {
-            if (ReferenceEquals(other, null))
-            {
-                return false;
-            }
-            if (ReferenceEquals(other, this))
-            {
-                return true;
-            }
-            if (!Equals(Item, other.Item)) return false;
-            return true;
-        }
-
-        public void WriteTo(pb::CodedOutputStream output)
-        {
-            if (item_ != null)
-            {
-                output.WriteRawTag(34);
-                output.WriteMessage(Item);
-            }
-        }
-
-        public int CalculateSize()
-        {
-            var size = 0;
-            if (item_ != null)
-            {
-                size += 1 + pb::CodedOutputStream.ComputeMessageSize(Item);
-            }
-            return size;
-        }
-
-        public void MergeFrom(AppliedItems other)
-        {
-            if (other == null)
-            {
-                return;
-            }
-            if (other.item_ != null)
-            {
-                if (item_ == null)
-                {
-                    item_ = new global::PokemonGo.RocketAPI.GeneratedCode.AppliedItem();
-                }
-                Item.MergeFrom(other.Item);
-            }
-        }
-
-        public void MergeFrom(pb::CodedInputStream input)
-        {
-            uint tag;
-            while ((tag = input.ReadTag()) != 0)
-            {
-                switch (tag)
-                {
-                    default:
-                        input.SkipLastField();
-                        break;
-                    case 34:
-                        {
-                            if (item_ == null)
-                            {
-                                item_ = new global::PokemonGo.RocketAPI.GeneratedCode.AppliedItem();
-                            }
-                            input.ReadMessage(item_);
-                            break;
-                        }
-                }
-            }
-        }
-
-        public override bool Equals(object other)
-        {
-            return Equals(other as AppliedItems);
-        }
-
-        public override int GetHashCode()
-        {
-            var hash = 1;
-            if (item_ != null) hash ^= Item.GetHashCode();
-            return hash;
-        }
-
-        partial void OnConstruction();
-
-        public override string ToString()
-        {
-            return pb::JsonFormatter.ToDiagnosticString(this);
-        }
-    }
-
-    [global::System.Diagnostics.DebuggerNonUserCodeAttribute()]
-    public sealed partial class AppliedItem : pb::IMessage<AppliedItem>
-    {
-        /// <summary>Field number for the "item_type" field.</summary>
-        public const int ItemTypeFieldNumber = 1;
-
-        /// <summary>Field number for the "item_type_category" field.</summary>
-        public const int ItemTypeCategoryFieldNumber = 2;
-
-        /// <summary>Field number for the "expire_ms" field.</summary>
-        public const int ExpireMsFieldNumber = 3;
-
-        /// <summary>Field number for the "applied_ms" field.</summary>
-        public const int AppliedMsFieldNumber = 4;
-
-        private static readonly pb::MessageParser<AppliedItem> _parser =
-            new pb::MessageParser<AppliedItem>(() => new AppliedItem());
-
-        private long appliedMs_;
-        private long expireMs_;
-        private global::PokemonGo.RocketAPI.GeneratedCode.ItemId itemType_ = 0;
-        private global::PokemonGo.RocketAPI.GeneratedCode.ItemType itemTypeCategory_ = 0;
-
-        public AppliedItem()
-        {
-            OnConstruction();
-        }
-
-        public AppliedItem(AppliedItem other) : this()
-        {
-            itemType_ = other.itemType_;
-            itemTypeCategory_ = other.itemTypeCategory_;
-            expireMs_ = other.expireMs_;
-            appliedMs_ = other.appliedMs_;
-        }
-
-        public static pb::MessageParser<AppliedItem> Parser
-        {
-            get { return _parser; }
-        }
-
-        public static pbr::MessageDescriptor Descriptor
-        {
-            get { return global::PokemonGo.RocketAPI.GeneratedCode.PayloadsReflection.Descriptor.MessageTypes[20]; }
-        }
-
-        public global::PokemonGo.RocketAPI.GeneratedCode.ItemId ItemType
-        {
-            get { return itemType_; }
-            set { itemType_ = value; }
-        }
-
-        public global::PokemonGo.RocketAPI.GeneratedCode.ItemType ItemTypeCategory
-        {
-            get { return itemTypeCategory_; }
-            set { itemTypeCategory_ = value; }
-        }
-
-        public long ExpireMs
-        {
-            get { return expireMs_; }
-            set { expireMs_ = value; }
-        }
-
-        public long AppliedMs
-        {
-            get { return appliedMs_; }
-            set { appliedMs_ = value; }
-        }
-
-        pbr::MessageDescriptor pb::IMessage.Descriptor
-        {
-            get { return Descriptor; }
-        }
-
-        public AppliedItem Clone()
-        {
-            return new AppliedItem(this);
-        }
-
-        public bool Equals(AppliedItem other)
-        {
-            if (ReferenceEquals(other, null))
-            {
-                return false;
-            }
-            if (ReferenceEquals(other, this))
-            {
-                return true;
-            }
-            if (ItemType != other.ItemType) return false;
-            if (ItemTypeCategory != other.ItemTypeCategory) return false;
-            if (ExpireMs != other.ExpireMs) return false;
-            if (AppliedMs != other.AppliedMs) return false;
-            return true;
-        }
-
-        public void WriteTo(pb::CodedOutputStream output)
-        {
-            if (ItemType != 0)
-            {
-                output.WriteRawTag(8);
-                output.WriteEnum((int)ItemType);
-            }
-            if (ItemTypeCategory != 0)
-            {
-                output.WriteRawTag(16);
-                output.WriteEnum((int)ItemTypeCategory);
-            }
-            if (ExpireMs != 0L)
-            {
-                output.WriteRawTag(24);
-                output.WriteInt64(ExpireMs);
-            }
-            if (AppliedMs != 0L)
-            {
-                output.WriteRawTag(32);
-                output.WriteInt64(AppliedMs);
-            }
-        }
-
-        public int CalculateSize()
-        {
-            var size = 0;
-            if (ItemType != 0)
-            {
-                size += 1 + pb::CodedOutputStream.ComputeEnumSize((int)ItemType);
-            }
-            if (ItemTypeCategory != 0)
-            {
-                size += 1 + pb::CodedOutputStream.ComputeEnumSize((int)ItemTypeCategory);
-            }
-            if (ExpireMs != 0L)
-            {
-                size += 1 + pb::CodedOutputStream.ComputeInt64Size(ExpireMs);
-            }
-            if (AppliedMs != 0L)
-            {
-                size += 1 + pb::CodedOutputStream.ComputeInt64Size(AppliedMs);
-            }
-            return size;
-        }
-
-        public void MergeFrom(AppliedItem other)
-        {
-            if (other == null)
-            {
-                return;
-            }
-            if (other.ItemType != 0)
-            {
-                ItemType = other.ItemType;
-            }
-            if (other.ItemTypeCategory != 0)
-            {
-                ItemTypeCategory = other.ItemTypeCategory;
-            }
-            if (other.ExpireMs != 0L)
-            {
-                ExpireMs = other.ExpireMs;
-            }
-            if (other.AppliedMs != 0L)
-            {
-                AppliedMs = other.AppliedMs;
-            }
-        }
-
-        public void MergeFrom(pb::CodedInputStream input)
-        {
-            uint tag;
-            while ((tag = input.ReadTag()) != 0)
-            {
-                switch (tag)
-                {
-                    default:
-                        input.SkipLastField();
-                        break;
-                    case 8:
-                        {
-                            itemType_ = (global::PokemonGo.RocketAPI.GeneratedCode.ItemId)input.ReadEnum();
-                            break;
-                        }
-                    case 16:
-                        {
-                            itemTypeCategory_ = (global::PokemonGo.RocketAPI.GeneratedCode.ItemType)input.ReadEnum();
-                            break;
-                        }
-                    case 24:
-                        {
-                            ExpireMs = input.ReadInt64();
-                            break;
-                        }
-                    case 32:
-                        {
-                            AppliedMs = input.ReadInt64();
-                            break;
-                        }
-                }
-            }
-        }
-
-        public override bool Equals(object other)
-        {
-            return Equals(other as AppliedItem);
-        }
-
-        public override int GetHashCode()
-        {
-            var hash = 1;
-            if (ItemType != 0) hash ^= ItemType.GetHashCode();
-            if (ItemTypeCategory != 0) hash ^= ItemTypeCategory.GetHashCode();
-            if (ExpireMs != 0L) hash ^= ExpireMs.GetHashCode();
-            if (AppliedMs != 0L) hash ^= AppliedMs.GetHashCode();
-            return hash;
-        }
-
-        partial void OnConstruction();
-
-        public override string ToString()
-        {
-            return pb::JsonFormatter.ToDiagnosticString(this);
-        }
-    }
-
-    [global::System.Diagnostics.DebuggerNonUserCodeAttribute()]
-    public sealed partial class EggIncubators : pb::IMessage<EggIncubators>
-    {
-        /// <summary>Field number for the "egg_incubator" field.</summary>
-        public const int EggIncubatorFieldNumber = 1;
-
-        private static readonly pb::MessageParser<EggIncubators> _parser =
-            new pb::MessageParser<EggIncubators>(() => new EggIncubators());
-
-        private global::PokemonGo.RocketAPI.GeneratedCode.EggIncubator eggIncubator_;
-
-        public EggIncubators()
-        {
-            OnConstruction();
-        }
-
-        public EggIncubators(EggIncubators other) : this()
-        {
-            EggIncubator = other.eggIncubator_ != null ? other.EggIncubator.Clone() : null;
-        }
-
-        public static pb::MessageParser<EggIncubators> Parser
-        {
-            get { return _parser; }
-        }
-
-        public static pbr::MessageDescriptor Descriptor
-        {
-            get { return global::PokemonGo.RocketAPI.GeneratedCode.PayloadsReflection.Descriptor.MessageTypes[21]; }
-        }
-
-        public global::PokemonGo.RocketAPI.GeneratedCode.EggIncubator EggIncubator
-        {
-            get { return eggIncubator_; }
-            set { eggIncubator_ = value; }
-        }
-
-        pbr::MessageDescriptor pb::IMessage.Descriptor
-        {
-            get { return Descriptor; }
-        }
-
-        public EggIncubators Clone()
-        {
-            return new EggIncubators(this);
-        }
-
-        public bool Equals(EggIncubators other)
-        {
-            if (ReferenceEquals(other, null))
-            {
-                return false;
-            }
-            if (ReferenceEquals(other, this))
-            {
-                return true;
-            }
-            if (!Equals(EggIncubator, other.EggIncubator)) return false;
-            return true;
-        }
-
-        public void WriteTo(pb::CodedOutputStream output)
-        {
-            if (eggIncubator_ != null)
-            {
-                output.WriteRawTag(10);
-                output.WriteMessage(EggIncubator);
-            }
-        }
-
-        public int CalculateSize()
-        {
-            var size = 0;
-            if (eggIncubator_ != null)
-            {
-                size += 1 + pb::CodedOutputStream.ComputeMessageSize(EggIncubator);
-            }
-            return size;
-        }
-
-        public void MergeFrom(EggIncubators other)
-        {
-            if (other == null)
-            {
-                return;
-            }
-            if (other.eggIncubator_ != null)
-            {
-                if (eggIncubator_ == null)
-                {
-                    eggIncubator_ = new global::PokemonGo.RocketAPI.GeneratedCode.EggIncubator();
-                }
-                EggIncubator.MergeFrom(other.EggIncubator);
-            }
-        }
-
-        public void MergeFrom(pb::CodedInputStream input)
-        {
-            uint tag;
-            while ((tag = input.ReadTag()) != 0)
-            {
-                switch (tag)
-                {
-                    default:
-                        input.SkipLastField();
-                        break;
-                    case 10:
-                        {
-                            if (eggIncubator_ == null)
-                            {
-                                eggIncubator_ = new global::PokemonGo.RocketAPI.GeneratedCode.EggIncubator();
-                            }
-                            input.ReadMessage(eggIncubator_);
-                            break;
-                        }
-                }
-            }
-        }
-
-        public override bool Equals(object other)
-        {
-            return Equals(other as EggIncubators);
-        }
-
-        public override int GetHashCode()
-        {
-            var hash = 1;
-            if (eggIncubator_ != null) hash ^= EggIncubator.GetHashCode();
-            return hash;
-        }
-
-        partial void OnConstruction();
-
-        public override string ToString()
-        {
-            return pb::JsonFormatter.ToDiagnosticString(this);
-        }
-    }
-
-    [global::System.Diagnostics.DebuggerNonUserCodeAttribute()]
-    public sealed partial class EggIncubator : pb::IMessage<EggIncubator>
-    {
-        /// <summary>Field number for the "item_id" field.</summary>
-        public const int ItemIdFieldNumber = 1;
-
-        /// <summary>Field number for the "item_type" field.</summary>
-        public const int ItemTypeFieldNumber = 2;
-
-        /// <summary>Field number for the "incubator_type" field.</summary>
-        public const int IncubatorTypeFieldNumber = 3;
-
-        /// <summary>Field number for the "uses_remaining" field.</summary>
-        public const int UsesRemainingFieldNumber = 4;
-
-        /// <summary>Field number for the "pokemon_id" field.</summary>
-        public const int PokemonIdFieldNumber = 5;
-
-        /// <summary>Field number for the "start_km_walked" field.</summary>
-        public const int StartKmWalkedFieldNumber = 6;
-
-        /// <summary>Field number for the "target_km_walked" field.</summary>
-        public const int TargetKmWalkedFieldNumber = 7;
-
-        private static readonly pb::MessageParser<EggIncubator> _parser =
-            new pb::MessageParser<EggIncubator>(() => new EggIncubator());
-
-        private global::PokemonGo.RocketAPI.GeneratedCode.EggIncubatorType incubatorType_ = 0;
-        private string itemId_ = "";
-        private global::PokemonGo.RocketAPI.GeneratedCode.ItemType itemType_ = 0;
-        private long pokemonId_;
-        private double startKmWalked_;
-        private double targetKmWalked_;
-        private int usesRemaining_;
-
-        public EggIncubator()
-        {
-            OnConstruction();
-        }
-
-        public EggIncubator(EggIncubator other) : this()
-        {
-            itemId_ = other.itemId_;
-            itemType_ = other.itemType_;
-            incubatorType_ = other.incubatorType_;
-            usesRemaining_ = other.usesRemaining_;
-            pokemonId_ = other.pokemonId_;
-            startKmWalked_ = other.startKmWalked_;
-            targetKmWalked_ = other.targetKmWalked_;
-        }
-
-        public static pb::MessageParser<EggIncubator> Parser
-        {
-            get { return _parser; }
-        }
-
-        public static pbr::MessageDescriptor Descriptor
-        {
-            get { return global::PokemonGo.RocketAPI.GeneratedCode.PayloadsReflection.Descriptor.MessageTypes[22]; }
-        }
-
-        public string ItemId
-        {
-            get { return itemId_; }
-            set { itemId_ = pb::ProtoPreconditions.CheckNotNull(value, "value"); }
-        }
-
-        public global::PokemonGo.RocketAPI.GeneratedCode.ItemType ItemType
-        {
-            get { return itemType_; }
-            set { itemType_ = value; }
-        }
-
-        public global::PokemonGo.RocketAPI.GeneratedCode.EggIncubatorType IncubatorType
-        {
-            get { return incubatorType_; }
-            set { incubatorType_ = value; }
-        }
-
-        public int UsesRemaining
-        {
-            get { return usesRemaining_; }
-            set { usesRemaining_ = value; }
-        }
-
-        /// <summary>
-        ///     TODO: Check if is PokemonType
-        /// </summary>
-        public long PokemonId
-        {
-            get { return pokemonId_; }
-            set { pokemonId_ = value; }
-        }
-
-        public double StartKmWalked
-        {
-            get { return startKmWalked_; }
-            set { startKmWalked_ = value; }
-        }
-
-        public double TargetKmWalked
-        {
-            get { return targetKmWalked_; }
-            set { targetKmWalked_ = value; }
-        }
-
-        pbr::MessageDescriptor pb::IMessage.Descriptor
-        {
-            get { return Descriptor; }
-        }
-
-        public EggIncubator Clone()
-        {
-            return new EggIncubator(this);
-        }
-
-        public bool Equals(EggIncubator other)
-        {
-            if (ReferenceEquals(other, null))
-            {
-                return false;
-            }
-            if (ReferenceEquals(other, this))
-            {
-                return true;
-            }
-            if (ItemId != other.ItemId) return false;
-            if (ItemType != other.ItemType) return false;
-            if (IncubatorType != other.IncubatorType) return false;
-            if (UsesRemaining != other.UsesRemaining) return false;
-            if (PokemonId != other.PokemonId) return false;
-            if (StartKmWalked != other.StartKmWalked) return false;
-            if (TargetKmWalked != other.TargetKmWalked) return false;
-            return true;
-        }
-
-        public void WriteTo(pb::CodedOutputStream output)
-        {
-            if (ItemId.Length != 0)
-            {
-                output.WriteRawTag(10);
-                output.WriteString(ItemId);
-            }
-            if (ItemType != 0)
-            {
-                output.WriteRawTag(16);
-                output.WriteEnum((int)ItemType);
-            }
-            if (IncubatorType != 0)
-            {
-                output.WriteRawTag(24);
-                output.WriteEnum((int)IncubatorType);
-            }
-            if (UsesRemaining != 0)
-            {
-                output.WriteRawTag(32);
-                output.WriteInt32(UsesRemaining);
-            }
-            if (PokemonId != 0L)
-            {
-                output.WriteRawTag(40);
-                output.WriteInt64(PokemonId);
-            }
-            if (StartKmWalked != 0D)
-            {
-                output.WriteRawTag(49);
-                output.WriteDouble(StartKmWalked);
-            }
-            if (TargetKmWalked != 0D)
-            {
-                output.WriteRawTag(57);
-                output.WriteDouble(TargetKmWalked);
-            }
-        }
-
-        public int CalculateSize()
-        {
-            var size = 0;
-            if (ItemId.Length != 0)
-            {
-                size += 1 + pb::CodedOutputStream.ComputeStringSize(ItemId);
-            }
-            if (ItemType != 0)
-            {
-                size += 1 + pb::CodedOutputStream.ComputeEnumSize((int)ItemType);
-            }
-            if (IncubatorType != 0)
-            {
-                size += 1 + pb::CodedOutputStream.ComputeEnumSize((int)IncubatorType);
-            }
-            if (UsesRemaining != 0)
-            {
-                size += 1 + pb::CodedOutputStream.ComputeInt32Size(UsesRemaining);
-            }
-            if (PokemonId != 0L)
-            {
-                size += 1 + pb::CodedOutputStream.ComputeInt64Size(PokemonId);
-            }
-            if (StartKmWalked != 0D)
-            {
-                size += 1 + 8;
-            }
-            if (TargetKmWalked != 0D)
-            {
-                size += 1 + 8;
-            }
-            return size;
-        }
-
-        public void MergeFrom(EggIncubator other)
-        {
-            if (other == null)
-            {
-                return;
-            }
-            if (other.ItemId.Length != 0)
-            {
-                ItemId = other.ItemId;
-            }
-            if (other.ItemType != 0)
-            {
-                ItemType = other.ItemType;
-            }
-            if (other.IncubatorType != 0)
-            {
-                IncubatorType = other.IncubatorType;
-            }
-            if (other.UsesRemaining != 0)
-            {
-                UsesRemaining = other.UsesRemaining;
-            }
-            if (other.PokemonId != 0L)
-            {
-                PokemonId = other.PokemonId;
-            }
-            if (other.StartKmWalked != 0D)
-            {
-                StartKmWalked = other.StartKmWalked;
-            }
-            if (other.TargetKmWalked != 0D)
-            {
-                TargetKmWalked = other.TargetKmWalked;
-            }
-        }
-
-        public void MergeFrom(pb::CodedInputStream input)
-        {
-            uint tag;
-            while ((tag = input.ReadTag()) != 0)
-            {
-                switch (tag)
-                {
-                    default:
-                        input.SkipLastField();
-                        break;
-                    case 10:
-                        {
-                            ItemId = input.ReadString();
-                            break;
-                        }
-                    case 16:
-                        {
-                            itemType_ = (global::PokemonGo.RocketAPI.GeneratedCode.ItemType)input.ReadEnum();
-                            break;
-                        }
-                    case 24:
-                        {
-                            incubatorType_ = (global::PokemonGo.RocketAPI.GeneratedCode.EggIncubatorType)input.ReadEnum();
-                            break;
-                        }
-                    case 32:
-                        {
-                            UsesRemaining = input.ReadInt32();
-                            break;
-                        }
-                    case 40:
-                        {
-                            PokemonId = input.ReadInt64();
-                            break;
-                        }
-                    case 49:
-                        {
-                            StartKmWalked = input.ReadDouble();
-                            break;
-                        }
-                    case 57:
-                        {
-                            TargetKmWalked = input.ReadDouble();
-                            break;
-                        }
-                }
-            }
-        }
-
-        public override bool Equals(object other)
-        {
-            return Equals(other as EggIncubator);
-        }
-
-        public override int GetHashCode()
-        {
-            var hash = 1;
-            if (ItemId.Length != 0) hash ^= ItemId.GetHashCode();
-            if (ItemType != 0) hash ^= ItemType.GetHashCode();
-            if (IncubatorType != 0) hash ^= IncubatorType.GetHashCode();
-            if (UsesRemaining != 0) hash ^= UsesRemaining.GetHashCode();
-            if (PokemonId != 0L) hash ^= PokemonId.GetHashCode();
-            if (StartKmWalked != 0D) hash ^= StartKmWalked.GetHashCode();
-            if (TargetKmWalked != 0D) hash ^= TargetKmWalked.GetHashCode();
-            return hash;
-        }
-
-        partial void OnConstruction();
-
-        public override string ToString()
-        {
-            return pb::JsonFormatter.ToDiagnosticString(this);
-        }
-    }
-
-    [global::System.Diagnostics.DebuggerNonUserCodeAttribute()]
-    public sealed partial class PokemonFamily : pb::IMessage<PokemonFamily>
-    {
-        /// <summary>Field number for the "family_id" field.</summary>
-        public const int FamilyIdFieldNumber = 1;
-
-        /// <summary>Field number for the "candy" field.</summary>
-        public const int CandyFieldNumber = 2;
-
-        private static readonly pb::MessageParser<PokemonFamily> _parser =
-            new pb::MessageParser<PokemonFamily>(() => new PokemonFamily());
-
-        private int candy_;
-        private global::PokemonGo.RocketAPI.GeneratedCode.PokemonFamilyId familyId_ = 0;
-
-        public PokemonFamily()
-        {
-            OnConstruction();
-        }
-
-        public PokemonFamily(PokemonFamily other) : this()
-        {
-            familyId_ = other.familyId_;
-            candy_ = other.candy_;
-        }
-
-        public static pb::MessageParser<PokemonFamily> Parser
-        {
-            get { return _parser; }
-        }
-
-        public static pbr::MessageDescriptor Descriptor
-        {
-            get { return global::PokemonGo.RocketAPI.GeneratedCode.PayloadsReflection.Descriptor.MessageTypes[23]; }
-        }
-
-        public global::PokemonGo.RocketAPI.GeneratedCode.PokemonFamilyId FamilyId
-        {
-            get { return familyId_; }
-            set { familyId_ = value; }
-        }
-
-        public int Candy
-        {
-            get { return candy_; }
-            set { candy_ = value; }
-        }
-
-        pbr::MessageDescriptor pb::IMessage.Descriptor
-        {
-            get { return Descriptor; }
-        }
-
-        public PokemonFamily Clone()
-        {
-            return new PokemonFamily(this);
-        }
-
-        public bool Equals(PokemonFamily other)
-        {
-            if (ReferenceEquals(other, null))
-            {
-                return false;
-            }
-            if (ReferenceEquals(other, this))
-            {
-                return true;
-            }
-            if (FamilyId != other.FamilyId) return false;
-            if (Candy != other.Candy) return false;
-            return true;
-        }
-
-        public void WriteTo(pb::CodedOutputStream output)
-        {
-            if (FamilyId != 0)
-            {
-                output.WriteRawTag(8);
-                output.WriteEnum((int)FamilyId);
-            }
-            if (Candy != 0)
-            {
-                output.WriteRawTag(16);
-                output.WriteInt32(Candy);
-            }
-        }
-
-        public int CalculateSize()
-        {
-            var size = 0;
-            if (FamilyId != 0)
-            {
-                size += 1 + pb::CodedOutputStream.ComputeEnumSize((int)FamilyId);
-            }
-            if (Candy != 0)
-            {
-                size += 1 + pb::CodedOutputStream.ComputeInt32Size(Candy);
-            }
-            return size;
-        }
-
-        public void MergeFrom(PokemonFamily other)
-        {
-            if (other == null)
-            {
-                return;
-            }
-            if (other.FamilyId != 0)
-            {
-                FamilyId = other.FamilyId;
-            }
-            if (other.Candy != 0)
-            {
-                Candy = other.Candy;
-            }
-        }
-
-        public void MergeFrom(pb::CodedInputStream input)
-        {
-            uint tag;
-            while ((tag = input.ReadTag()) != 0)
-            {
-                switch (tag)
-                {
-                    default:
-                        input.SkipLastField();
-                        break;
-                    case 8:
-                        {
-                            familyId_ = (global::PokemonGo.RocketAPI.GeneratedCode.PokemonFamilyId)input.ReadEnum();
-                            break;
-                        }
-                    case 16:
-                        {
-                            Candy = input.ReadInt32();
-                            break;
-                        }
-                }
-            }
-        }
-
-        public override bool Equals(object other)
-        {
-            return Equals(other as PokemonFamily);
-        }
-
-        public override int GetHashCode()
-        {
-            var hash = 1;
-            if (FamilyId != 0) hash ^= FamilyId.GetHashCode();
-            if (Candy != 0) hash ^= Candy.GetHashCode();
-            return hash;
-        }
-
-        partial void OnConstruction();
-
-        public override string ToString()
-        {
-            return pb::JsonFormatter.ToDiagnosticString(this);
-        }
-    }
-
-    [global::System.Diagnostics.DebuggerNonUserCodeAttribute()]
-    public sealed partial class GetMapObjectsRequest : pb::IMessage<GetMapObjectsRequest>
-    {
-        /// <summary>Field number for the "cell_id" field.</summary>
-        public const int CellIdFieldNumber = 1;
-
-        /// <summary>Field number for the "since_timestamp_ms" field.</summary>
-        public const int SinceTimestampMsFieldNumber = 2;
-
-        /// <summary>Field number for the "latitude" field.</summary>
-        public const int LatitudeFieldNumber = 3;
-
-        /// <summary>Field number for the "longitude" field.</summary>
-        public const int LongitudeFieldNumber = 4;
-
-        private static readonly pb::MessageParser<GetMapObjectsRequest> _parser =
-            new pb::MessageParser<GetMapObjectsRequest>(() => new GetMapObjectsRequest());
-
-        private pb::ByteString cellId_ = pb::ByteString.Empty;
-        private double latitude_;
-        private double longitude_;
-        private pb::ByteString sinceTimestampMs_ = pb::ByteString.Empty;
-
-        public GetMapObjectsRequest()
-        {
-            OnConstruction();
-        }
-
-        public GetMapObjectsRequest(GetMapObjectsRequest other) : this()
-        {
-            cellId_ = other.cellId_;
-            sinceTimestampMs_ = other.sinceTimestampMs_;
-            latitude_ = other.latitude_;
-            longitude_ = other.longitude_;
-        }
-
-        public static pb::MessageParser<GetMapObjectsRequest> Parser
-        {
-            get { return _parser; }
-        }
-
-        public static pbr::MessageDescriptor Descriptor
-        {
-            get { return global::PokemonGo.RocketAPI.GeneratedCode.PayloadsReflection.Descriptor.MessageTypes[24]; }
-        }
-
-        public pb::ByteString CellId
-        {
-            get { return cellId_; }
-            set { cellId_ = pb::ProtoPreconditions.CheckNotNull(value, "value"); }
-        }
-
-        public pb::ByteString SinceTimestampMs
-        {
-            get { return sinceTimestampMs_; }
-            set { sinceTimestampMs_ = pb::ProtoPreconditions.CheckNotNull(value, "value"); }
-        }
-
-        public double Latitude
-        {
-            get { return latitude_; }
-            set { latitude_ = value; }
-        }
-
-        public double Longitude
-        {
-            get { return longitude_; }
-            set { longitude_ = value; }
-        }
-
-        pbr::MessageDescriptor pb::IMessage.Descriptor
-        {
-            get { return Descriptor; }
-        }
-
-        public GetMapObjectsRequest Clone()
-        {
-            return new GetMapObjectsRequest(this);
-        }
-
-        public bool Equals(GetMapObjectsRequest other)
-        {
-            if (ReferenceEquals(other, null))
-            {
-                return false;
-            }
-            if (ReferenceEquals(other, this))
-            {
-                return true;
-            }
-            if (CellId != other.CellId) return false;
-            if (SinceTimestampMs != other.SinceTimestampMs) return false;
-            if (Latitude != other.Latitude) return false;
-            if (Longitude != other.Longitude) return false;
-            return true;
-        }
-
-        public void WriteTo(pb::CodedOutputStream output)
-        {
-            if (CellId.Length != 0)
-            {
-                output.WriteRawTag(10);
-                output.WriteBytes(CellId);
-            }
-            if (SinceTimestampMs.Length != 0)
-            {
-                output.WriteRawTag(18);
-                output.WriteBytes(SinceTimestampMs);
-            }
-            if (Latitude != 0D)
-            {
-                output.WriteRawTag(25);
-                output.WriteDouble(Latitude);
-            }
-            if (Longitude != 0D)
-            {
-                output.WriteRawTag(33);
-                output.WriteDouble(Longitude);
-            }
-        }
-
-        public int CalculateSize()
-        {
-            var size = 0;
-            if (CellId.Length != 0)
-            {
-                size += 1 + pb::CodedOutputStream.ComputeBytesSize(CellId);
-            }
-            if (SinceTimestampMs.Length != 0)
-            {
-                size += 1 + pb::CodedOutputStream.ComputeBytesSize(SinceTimestampMs);
-            }
-            if (Latitude != 0D)
-            {
-                size += 1 + 8;
-            }
-            if (Longitude != 0D)
-            {
-                size += 1 + 8;
-            }
-            return size;
-        }
-
-        public void MergeFrom(GetMapObjectsRequest other)
-        {
-            if (other == null)
-            {
-                return;
-            }
-            if (other.CellId.Length != 0)
-            {
-                CellId = other.CellId;
-            }
-            if (other.SinceTimestampMs.Length != 0)
-            {
-                SinceTimestampMs = other.SinceTimestampMs;
-            }
-            if (other.Latitude != 0D)
-            {
-                Latitude = other.Latitude;
-            }
-            if (other.Longitude != 0D)
-            {
-                Longitude = other.Longitude;
-            }
-        }
-
-        public void MergeFrom(pb::CodedInputStream input)
-        {
-            uint tag;
-            while ((tag = input.ReadTag()) != 0)
-            {
-                switch (tag)
-                {
-                    default:
-                        input.SkipLastField();
-                        break;
-                    case 10:
-                        {
-                            CellId = input.ReadBytes();
-                            break;
-                        }
-                    case 18:
-                        {
-                            SinceTimestampMs = input.ReadBytes();
-                            break;
-                        }
-                    case 25:
-                        {
-                            Latitude = input.ReadDouble();
-                            break;
-                        }
-                    case 33:
-                        {
-                            Longitude = input.ReadDouble();
-                            break;
-                        }
-                }
-            }
-        }
-
-        public override bool Equals(object other)
-        {
-            return Equals(other as GetMapObjectsRequest);
-        }
-
-        public override int GetHashCode()
-        {
-            var hash = 1;
-            if (CellId.Length != 0) hash ^= CellId.GetHashCode();
-            if (SinceTimestampMs.Length != 0) hash ^= SinceTimestampMs.GetHashCode();
-            if (Latitude != 0D) hash ^= Latitude.GetHashCode();
-            if (Longitude != 0D) hash ^= Longitude.GetHashCode();
-            return hash;
-        }
-
-        partial void OnConstruction();
-
-        public override string ToString()
-        {
-            return pb::JsonFormatter.ToDiagnosticString(this);
-        }
-    }
-
-    [global::System.Diagnostics.DebuggerNonUserCodeAttribute()]
-    public sealed partial class GetMapObjectsResponse : pb::IMessage<GetMapObjectsResponse>
-    {
-        /// <summary>Field number for the "map_cells" field.</summary>
-        public const int MapCellsFieldNumber = 1;
-
-        /// <summary>Field number for the "status" field.</summary>
-        public const int StatusFieldNumber = 2;
-
-        private static readonly pb::MessageParser<GetMapObjectsResponse> _parser =
-            new pb::MessageParser<GetMapObjectsResponse>(() => new GetMapObjectsResponse());
-
-        private static readonly pb::FieldCodec<global::PokemonGo.RocketAPI.GeneratedCode.MapCell>
-            _repeated_mapCells_codec
-                = pb::FieldCodec.ForMessage(10, global::PokemonGo.RocketAPI.GeneratedCode.MapCell.Parser);
-
-        private readonly pbc::RepeatedField<global::PokemonGo.RocketAPI.GeneratedCode.MapCell> mapCells_ =
-            new pbc::RepeatedField<global::PokemonGo.RocketAPI.GeneratedCode.MapCell>();
-
-        private global::PokemonGo.RocketAPI.GeneratedCode.MapObjectsStatus status_ = 0;
-
-        public GetMapObjectsResponse()
-        {
-            OnConstruction();
-        }
-
-        public GetMapObjectsResponse(GetMapObjectsResponse other) : this()
-        {
-            mapCells_ = other.mapCells_.Clone();
-            status_ = other.status_;
-        }
-
-        public static pb::MessageParser<GetMapObjectsResponse> Parser
-        {
-            get { return _parser; }
-        }
-
-        public static pbr::MessageDescriptor Descriptor
-        {
-            get { return global::PokemonGo.RocketAPI.GeneratedCode.PayloadsReflection.Descriptor.MessageTypes[25]; }
-        }
-
-        public pbc::RepeatedField<global::PokemonGo.RocketAPI.GeneratedCode.MapCell> MapCells
-        {
-            get { return mapCells_; }
-        }
-
-        public global::PokemonGo.RocketAPI.GeneratedCode.MapObjectsStatus Status
-        {
-            get { return status_; }
-            set { status_ = value; }
-        }
-
-        pbr::MessageDescriptor pb::IMessage.Descriptor
-        {
-            get { return Descriptor; }
-        }
-
-        public GetMapObjectsResponse Clone()
-        {
-            return new GetMapObjectsResponse(this);
-        }
-
-        public bool Equals(GetMapObjectsResponse other)
-        {
-            if (ReferenceEquals(other, null))
-            {
-                return false;
-            }
-            if (ReferenceEquals(other, this))
-            {
-                return true;
-            }
-            if (!mapCells_.Equals(other.mapCells_)) return false;
-            if (Status != other.Status) return false;
-            return true;
-        }
-
-        public void WriteTo(pb::CodedOutputStream output)
-        {
-            mapCells_.WriteTo(output, _repeated_mapCells_codec);
-            if (Status != 0)
-            {
-                output.WriteRawTag(16);
-                output.WriteEnum((int)Status);
-            }
-        }
-
-        public int CalculateSize()
-        {
-            var size = 0;
-            size += mapCells_.CalculateSize(_repeated_mapCells_codec);
-            if (Status != 0)
-            {
-                size += 1 + pb::CodedOutputStream.ComputeEnumSize((int)Status);
-            }
-            return size;
-        }
-
-        public void MergeFrom(GetMapObjectsResponse other)
-        {
-            if (other == null)
-            {
-                return;
-            }
-            mapCells_.Add(other.mapCells_);
-            if (other.Status != 0)
-            {
-                Status = other.Status;
-            }
-        }
-
-        public void MergeFrom(pb::CodedInputStream input)
-        {
-            uint tag;
-            while ((tag = input.ReadTag()) != 0)
-            {
-                switch (tag)
-                {
-                    default:
-                        input.SkipLastField();
-                        break;
-                    case 10:
-                        {
-                            mapCells_.AddEntriesFrom(input, _repeated_mapCells_codec);
-                            break;
-                        }
-                    case 16:
-                        {
-                            status_ = (global::PokemonGo.RocketAPI.GeneratedCode.MapObjectsStatus)input.ReadEnum();
-                            break;
-                        }
-                }
-            }
-        }
-
-        public override bool Equals(object other)
-        {
-            return Equals(other as GetMapObjectsResponse);
-        }
-
-        public override int GetHashCode()
-        {
-            var hash = 1;
-            hash ^= mapCells_.GetHashCode();
-            if (Status != 0) hash ^= Status.GetHashCode();
-            return hash;
-        }
-
-        partial void OnConstruction();
-
-        public override string ToString()
-        {
-            return pb::JsonFormatter.ToDiagnosticString(this);
-        }
-    }
-
-    [global::System.Diagnostics.DebuggerNonUserCodeAttribute()]
-    public sealed partial class MapCell : pb::IMessage<MapCell>
-    {
-        /// <summary>Field number for the "s2_cell_id" field.</summary>
-        public const int S2CellIdFieldNumber = 1;
-
-        /// <summary>Field number for the "current_timestamp_ms" field.</summary>
-        public const int CurrentTimestampMsFieldNumber = 2;
-
-        /// <summary>Field number for the "forts" field.</summary>
-        public const int FortsFieldNumber = 3;
-
-        /// <summary>Field number for the "spawn_points" field.</summary>
-        public const int SpawnPointsFieldNumber = 4;
-
-        /// <summary>Field number for the "deleted_objects" field.</summary>
-        public const int DeletedObjectsFieldNumber = 6;
-
-        /// <summary>Field number for the "is_truncated_list" field.</summary>
-        public const int IsTruncatedListFieldNumber = 7;
-
-        /// <summary>Field number for the "fort_summaries" field.</summary>
-        public const int FortSummariesFieldNumber = 8;
-
-        /// <summary>Field number for the "decimated_spawn_points" field.</summary>
-        public const int DecimatedSpawnPointsFieldNumber = 9;
-
-        /// <summary>Field number for the "wild_pokemons" field.</summary>
-        public const int WildPokemonsFieldNumber = 5;
-
-        /// <summary>Field number for the "catchable_pokemons" field.</summary>
-        public const int CatchablePokemonsFieldNumber = 10;
-
-        /// <summary>Field number for the "nearby_pokemons" field.</summary>
-        public const int NearbyPokemonsFieldNumber = 11;
-
-        private static readonly pb::MessageParser<MapCell> _parser = new pb::MessageParser<MapCell>(() => new MapCell());
-
-        private static readonly pb::FieldCodec<global::PokemonGo.RocketAPI.GeneratedCode.FortData> _repeated_forts_codec
-            = pb::FieldCodec.ForMessage(26, global::PokemonGo.RocketAPI.GeneratedCode.FortData.Parser);
-
-        private static readonly pb::FieldCodec<global::PokemonGo.RocketAPI.GeneratedCode.SpawnPoint>
-            _repeated_spawnPoints_codec
-                = pb::FieldCodec.ForMessage(34, global::PokemonGo.RocketAPI.GeneratedCode.SpawnPoint.Parser);
-
-        private static readonly pb::FieldCodec<string> _repeated_deletedObjects_codec
-            = pb::FieldCodec.ForString(50);
-
-        private static readonly pb::FieldCodec<global::PokemonGo.RocketAPI.GeneratedCode.FortSummary>
-            _repeated_fortSummaries_codec
-                = pb::FieldCodec.ForMessage(66, global::PokemonGo.RocketAPI.GeneratedCode.FortSummary.Parser);
-
-        private static readonly pb::FieldCodec<global::PokemonGo.RocketAPI.GeneratedCode.SpawnPoint>
-            _repeated_decimatedSpawnPoints_codec
-                = pb::FieldCodec.ForMessage(74, global::PokemonGo.RocketAPI.GeneratedCode.SpawnPoint.Parser);
-
-        private static readonly pb::FieldCodec<global::PokemonGo.RocketAPI.GeneratedCode.WildPokemon>
-            _repeated_wildPokemons_codec
-                = pb::FieldCodec.ForMessage(42, global::PokemonGo.RocketAPI.GeneratedCode.WildPokemon.Parser);
-
-        private static readonly pb::FieldCodec<global::PokemonGo.RocketAPI.GeneratedCode.MapPokemon>
-            _repeated_catchablePokemons_codec
-                = pb::FieldCodec.ForMessage(82, global::PokemonGo.RocketAPI.GeneratedCode.MapPokemon.Parser);
-
-        private static readonly pb::FieldCodec<global::PokemonGo.RocketAPI.GeneratedCode.NearbyPokemon>
-            _repeated_nearbyPokemons_codec
-                = pb::FieldCodec.ForMessage(90, global::PokemonGo.RocketAPI.GeneratedCode.NearbyPokemon.Parser);
-
-        private readonly pbc::RepeatedField<global::PokemonGo.RocketAPI.GeneratedCode.MapPokemon> catchablePokemons_ =
-            new pbc::RepeatedField<global::PokemonGo.RocketAPI.GeneratedCode.MapPokemon>();
-
-        private readonly pbc::RepeatedField<global::PokemonGo.RocketAPI.GeneratedCode.SpawnPoint> decimatedSpawnPoints_
-            = new pbc::RepeatedField<global::PokemonGo.RocketAPI.GeneratedCode.SpawnPoint>();
-
-        private readonly pbc::RepeatedField<string> deletedObjects_ = new pbc::RepeatedField<string>();
-
-        private readonly pbc::RepeatedField<global::PokemonGo.RocketAPI.GeneratedCode.FortData> forts_ =
-            new pbc::RepeatedField<global::PokemonGo.RocketAPI.GeneratedCode.FortData>();
-
-        private readonly pbc::RepeatedField<global::PokemonGo.RocketAPI.GeneratedCode.FortSummary> fortSummaries_ =
-            new pbc::RepeatedField<global::PokemonGo.RocketAPI.GeneratedCode.FortSummary>();
-
-        private readonly pbc::RepeatedField<global::PokemonGo.RocketAPI.GeneratedCode.NearbyPokemon> nearbyPokemons_ =
-            new pbc::RepeatedField<global::PokemonGo.RocketAPI.GeneratedCode.NearbyPokemon>();
-
-        private readonly pbc::RepeatedField<global::PokemonGo.RocketAPI.GeneratedCode.SpawnPoint> spawnPoints_ =
-            new pbc::RepeatedField<global::PokemonGo.RocketAPI.GeneratedCode.SpawnPoint>();
-
-        private readonly pbc::RepeatedField<global::PokemonGo.RocketAPI.GeneratedCode.WildPokemon> wildPokemons_ =
-            new pbc::RepeatedField<global::PokemonGo.RocketAPI.GeneratedCode.WildPokemon>();
-
-        private long currentTimestampMs_;
-        private bool isTruncatedList_;
-        private ulong s2CellId_;
-
-        public MapCell()
-        {
-            OnConstruction();
-        }
-
-        public MapCell(MapCell other) : this()
-        {
-            s2CellId_ = other.s2CellId_;
-            currentTimestampMs_ = other.currentTimestampMs_;
-            forts_ = other.forts_.Clone();
-            spawnPoints_ = other.spawnPoints_.Clone();
-            deletedObjects_ = other.deletedObjects_.Clone();
-            isTruncatedList_ = other.isTruncatedList_;
-            fortSummaries_ = other.fortSummaries_.Clone();
-            decimatedSpawnPoints_ = other.decimatedSpawnPoints_.Clone();
-            wildPokemons_ = other.wildPokemons_.Clone();
-            catchablePokemons_ = other.catchablePokemons_.Clone();
-            nearbyPokemons_ = other.nearbyPokemons_.Clone();
-        }
-
-        public static pb::MessageParser<MapCell> Parser
-        {
-            get { return _parser; }
-        }
-
-        public static pbr::MessageDescriptor Descriptor
-        {
-            get { return global::PokemonGo.RocketAPI.GeneratedCode.PayloadsReflection.Descriptor.MessageTypes[26]; }
-        }
-
-        /// <summary>
-        ///     S2 geographic area that the cell covers (http://s2map.com/)
-        ///     (https://code.google.com/archive/p/s2-geometry-library/)
-        /// </summary>
-        public ulong S2CellId
-        {
-            get { return s2CellId_; }
-            set { s2CellId_ = value; }
-        }
-
-        public long CurrentTimestampMs
-        {
-            get { return currentTimestampMs_; }
-            set { currentTimestampMs_ = value; }
-        }
-
-        public pbc::RepeatedField<global::PokemonGo.RocketAPI.GeneratedCode.FortData> Forts
-        {
-            get { return forts_; }
-        }
-
-        public pbc::RepeatedField<global::PokemonGo.RocketAPI.GeneratedCode.SpawnPoint> SpawnPoints
-        {
-            get { return spawnPoints_; }
-        }
-
-        public pbc::RepeatedField<string> DeletedObjects
-        {
-            get { return deletedObjects_; }
-        }
-
-        public bool IsTruncatedList
-        {
-            get { return isTruncatedList_; }
-            set { isTruncatedList_ = value; }
-        }
-
-        public pbc::RepeatedField<global::PokemonGo.RocketAPI.GeneratedCode.FortSummary> FortSummaries
-        {
-            get { return fortSummaries_; }
-        }
-
-        public pbc::RepeatedField<global::PokemonGo.RocketAPI.GeneratedCode.SpawnPoint> DecimatedSpawnPoints
-        {
-            get { return decimatedSpawnPoints_; }
-        }
-
-        /// <summary>
-        ///     Pokemon within 2 steps or less.
-        /// </summary>
-        public pbc::RepeatedField<global::PokemonGo.RocketAPI.GeneratedCode.WildPokemon> WildPokemons
-        {
-            get { return wildPokemons_; }
-        }
-
-        /// <summary>
-        ///     Pokemon within 1 step or none.
-        /// </summary>
-        public pbc::RepeatedField<global::PokemonGo.RocketAPI.GeneratedCode.MapPokemon> CatchablePokemons
-        {
-            get { return catchablePokemons_; }
-        }
-
-        /// <summary>
-        ///     Pokemon farther away than 2 steps, but still in the area.
-        /// </summary>
-        public pbc::RepeatedField<global::PokemonGo.RocketAPI.GeneratedCode.NearbyPokemon> NearbyPokemons
-        {
-            get { return nearbyPokemons_; }
-        }
-
-        pbr::MessageDescriptor pb::IMessage.Descriptor
-        {
-            get { return Descriptor; }
-        }
-
-        public MapCell Clone()
-        {
-            return new MapCell(this);
-        }
-
-        public bool Equals(MapCell other)
-        {
-            if (ReferenceEquals(other, null))
-            {
-                return false;
-            }
-            if (ReferenceEquals(other, this))
-            {
-                return true;
-            }
-            if (S2CellId != other.S2CellId) return false;
-            if (CurrentTimestampMs != other.CurrentTimestampMs) return false;
-            if (!forts_.Equals(other.forts_)) return false;
-            if (!spawnPoints_.Equals(other.spawnPoints_)) return false;
-            if (!deletedObjects_.Equals(other.deletedObjects_)) return false;
-            if (IsTruncatedList != other.IsTruncatedList) return false;
-            if (!fortSummaries_.Equals(other.fortSummaries_)) return false;
-            if (!decimatedSpawnPoints_.Equals(other.decimatedSpawnPoints_)) return false;
-            if (!wildPokemons_.Equals(other.wildPokemons_)) return false;
-            if (!catchablePokemons_.Equals(other.catchablePokemons_)) return false;
-            if (!nearbyPokemons_.Equals(other.nearbyPokemons_)) return false;
-            return true;
-        }
-
-        public void WriteTo(pb::CodedOutputStream output)
-        {
-            if (S2CellId != 0UL)
-            {
-                output.WriteRawTag(8);
-                output.WriteUInt64(S2CellId);
-            }
-            if (CurrentTimestampMs != 0L)
-            {
-                output.WriteRawTag(16);
-                output.WriteInt64(CurrentTimestampMs);
-            }
-            forts_.WriteTo(output, _repeated_forts_codec);
-            spawnPoints_.WriteTo(output, _repeated_spawnPoints_codec);
-            wildPokemons_.WriteTo(output, _repeated_wildPokemons_codec);
-            deletedObjects_.WriteTo(output, _repeated_deletedObjects_codec);
-            if (IsTruncatedList != false)
-            {
-                output.WriteRawTag(56);
-                output.WriteBool(IsTruncatedList);
-            }
-            fortSummaries_.WriteTo(output, _repeated_fortSummaries_codec);
-            decimatedSpawnPoints_.WriteTo(output, _repeated_decimatedSpawnPoints_codec);
-            catchablePokemons_.WriteTo(output, _repeated_catchablePokemons_codec);
-            nearbyPokemons_.WriteTo(output, _repeated_nearbyPokemons_codec);
-        }
-
-        public int CalculateSize()
-        {
-            var size = 0;
-            if (S2CellId != 0UL)
-            {
-                size += 1 + pb::CodedOutputStream.ComputeUInt64Size(S2CellId);
-            }
-            if (CurrentTimestampMs != 0L)
-            {
-                size += 1 + pb::CodedOutputStream.ComputeInt64Size(CurrentTimestampMs);
-            }
-            size += forts_.CalculateSize(_repeated_forts_codec);
-            size += spawnPoints_.CalculateSize(_repeated_spawnPoints_codec);
-            size += deletedObjects_.CalculateSize(_repeated_deletedObjects_codec);
-            if (IsTruncatedList != false)
-            {
-                size += 1 + 1;
-            }
-            size += fortSummaries_.CalculateSize(_repeated_fortSummaries_codec);
-            size += decimatedSpawnPoints_.CalculateSize(_repeated_decimatedSpawnPoints_codec);
-            size += wildPokemons_.CalculateSize(_repeated_wildPokemons_codec);
-            size += catchablePokemons_.CalculateSize(_repeated_catchablePokemons_codec);
-            size += nearbyPokemons_.CalculateSize(_repeated_nearbyPokemons_codec);
-            return size;
-        }
-
-        public void MergeFrom(MapCell other)
-        {
-            if (other == null)
-            {
-                return;
-            }
-            if (other.S2CellId != 0UL)
-            {
-                S2CellId = other.S2CellId;
-            }
-            if (other.CurrentTimestampMs != 0L)
-            {
-                CurrentTimestampMs = other.CurrentTimestampMs;
-            }
-            forts_.Add(other.forts_);
-            spawnPoints_.Add(other.spawnPoints_);
-            deletedObjects_.Add(other.deletedObjects_);
-            if (other.IsTruncatedList != false)
-            {
-                IsTruncatedList = other.IsTruncatedList;
-            }
-            fortSummaries_.Add(other.fortSummaries_);
-            decimatedSpawnPoints_.Add(other.decimatedSpawnPoints_);
-            wildPokemons_.Add(other.wildPokemons_);
-            catchablePokemons_.Add(other.catchablePokemons_);
-            nearbyPokemons_.Add(other.nearbyPokemons_);
-        }
-
-        public void MergeFrom(pb::CodedInputStream input)
-        {
-            uint tag;
-            while ((tag = input.ReadTag()) != 0)
-            {
-                switch (tag)
-                {
-                    default:
-                        input.SkipLastField();
-                        break;
-                    case 8:
-                        {
-                            S2CellId = input.ReadUInt64();
-                            break;
-                        }
-                    case 16:
-                        {
-                            CurrentTimestampMs = input.ReadInt64();
-                            break;
-                        }
-                    case 26:
-                        {
-                            forts_.AddEntriesFrom(input, _repeated_forts_codec);
-                            break;
-                        }
-                    case 34:
-                        {
-                            spawnPoints_.AddEntriesFrom(input, _repeated_spawnPoints_codec);
-                            break;
-                        }
-                    case 42:
-                        {
-                            wildPokemons_.AddEntriesFrom(input, _repeated_wildPokemons_codec);
-                            break;
-                        }
-                    case 50:
-                        {
-                            deletedObjects_.AddEntriesFrom(input, _repeated_deletedObjects_codec);
-                            break;
-                        }
-                    case 56:
-                        {
-                            IsTruncatedList = input.ReadBool();
-                            break;
-                        }
-                    case 66:
-                        {
-                            fortSummaries_.AddEntriesFrom(input, _repeated_fortSummaries_codec);
-                            break;
-                        }
-                    case 74:
-                        {
-                            decimatedSpawnPoints_.AddEntriesFrom(input, _repeated_decimatedSpawnPoints_codec);
-                            break;
-                        }
-                    case 82:
-                        {
-                            catchablePokemons_.AddEntriesFrom(input, _repeated_catchablePokemons_codec);
-                            break;
-                        }
-                    case 90:
-                        {
-                            nearbyPokemons_.AddEntriesFrom(input, _repeated_nearbyPokemons_codec);
-                            break;
-                        }
-                }
-            }
-        }
-
-        public override bool Equals(object other)
-        {
-            return Equals(other as MapCell);
-        }
-
-        public override int GetHashCode()
-        {
-            var hash = 1;
-            if (S2CellId != 0UL) hash ^= S2CellId.GetHashCode();
-            if (CurrentTimestampMs != 0L) hash ^= CurrentTimestampMs.GetHashCode();
-            hash ^= forts_.GetHashCode();
-            hash ^= spawnPoints_.GetHashCode();
-            hash ^= deletedObjects_.GetHashCode();
-            if (IsTruncatedList != false) hash ^= IsTruncatedList.GetHashCode();
-            hash ^= fortSummaries_.GetHashCode();
-            hash ^= decimatedSpawnPoints_.GetHashCode();
-            hash ^= wildPokemons_.GetHashCode();
-            hash ^= catchablePokemons_.GetHashCode();
-            hash ^= nearbyPokemons_.GetHashCode();
-            return hash;
-        }
-
-        partial void OnConstruction();
-
-        public override string ToString()
-        {
-            return pb::JsonFormatter.ToDiagnosticString(this);
-        }
-    }
-
-    [global::System.Diagnostics.DebuggerNonUserCodeAttribute()]
-    public sealed partial class FortData : pb::IMessage<FortData>
-    {
-        /// <summary>Field number for the "id" field.</summary>
-        public const int IdFieldNumber = 1;
-
-        /// <summary>Field number for the "last_modified_timestamp_ms" field.</summary>
-        public const int LastModifiedTimestampMsFieldNumber = 2;
-
-        /// <summary>Field number for the "latitude" field.</summary>
-        public const int LatitudeFieldNumber = 3;
-
-        /// <summary>Field number for the "longitude" field.</summary>
-        public const int LongitudeFieldNumber = 4;
-
-        /// <summary>Field number for the "enabled" field.</summary>
-        public const int EnabledFieldNumber = 8;
-
-        /// <summary>Field number for the "type" field.</summary>
-        public const int TypeFieldNumber = 9;
-
-        /// <summary>Field number for the "owned_by_team" field.</summary>
-        public const int OwnedByTeamFieldNumber = 5;
-
-        /// <summary>Field number for the "guard_pokemon_id" field.</summary>
-        public const int GuardPokemonIdFieldNumber = 6;
-
-        /// <summary>Field number for the "guard_pokemon_cp" field.</summary>
-        public const int GuardPokemonCpFieldNumber = 7;
-
-        /// <summary>Field number for the "gym_points" field.</summary>
-        public const int GymPointsFieldNumber = 10;
-
-        /// <summary>Field number for the "is_in_battle" field.</summary>
-        public const int IsInBattleFieldNumber = 11;
-
-        /// <summary>Field number for the "cooldown_complete_timestamp_ms" field.</summary>
-        public const int CooldownCompleteTimestampMsFieldNumber = 14;
-
-        /// <summary>Field number for the "sponsor" field.</summary>
-        public const int SponsorFieldNumber = 15;
-
-        /// <summary>Field number for the "rendering_type" field.</summary>
-        public const int RenderingTypeFieldNumber = 16;
-
-        /// <summary>Field number for the "active_fort_modifier" field.</summary>
-        public const int ActiveFortModifierFieldNumber = 12;
-
-        /// <summary>Field number for the "lure_info" field.</summary>
-        public const int LureInfoFieldNumber = 13;
-
-        private static readonly pb::MessageParser<FortData> _parser =
-            new pb::MessageParser<FortData>(() => new FortData());
-
-        private pb::ByteString activeFortModifier_ = pb::ByteString.Empty;
-        private long cooldownCompleteTimestampMs_;
-        private bool enabled_;
-        private int guardPokemonCp_;
-        private global::PokemonGo.RocketAPI.GeneratedCode.PokemonId guardPokemonId_ = 0;
-        private long gymPoints_;
-        private string id_ = "";
-        private bool isInBattle_;
-        private long lastModifiedTimestampMs_;
-        private double latitude_;
-        private double longitude_;
-        private global::PokemonGo.RocketAPI.GeneratedCode.FortLureInfo lureInfo_;
-        private global::PokemonGo.RocketAPI.GeneratedCode.TeamColor ownedByTeam_ = 0;
-        private global::PokemonGo.RocketAPI.GeneratedCode.FortRenderingType renderingType_ = 0;
-        private global::PokemonGo.RocketAPI.GeneratedCode.FortSponsor sponsor_ = 0;
-        private global::PokemonGo.RocketAPI.GeneratedCode.FortType type_ = 0;
-
-        public FortData()
-        {
-            OnConstruction();
-        }
-
-        public FortData(FortData other) : this()
-        {
-            id_ = other.id_;
-            lastModifiedTimestampMs_ = other.lastModifiedTimestampMs_;
-            latitude_ = other.latitude_;
-            longitude_ = other.longitude_;
-            enabled_ = other.enabled_;
-            type_ = other.type_;
-            ownedByTeam_ = other.ownedByTeam_;
-            guardPokemonId_ = other.guardPokemonId_;
-            guardPokemonCp_ = other.guardPokemonCp_;
-            gymPoints_ = other.gymPoints_;
-            isInBattle_ = other.isInBattle_;
-            cooldownCompleteTimestampMs_ = other.cooldownCompleteTimestampMs_;
-            sponsor_ = other.sponsor_;
-            renderingType_ = other.renderingType_;
-            activeFortModifier_ = other.activeFortModifier_;
-            LureInfo = other.lureInfo_ != null ? other.LureInfo.Clone() : null;
-        }
-
-        public static pb::MessageParser<FortData> Parser
-        {
-            get { return _parser; }
-        }
-
-        public static pbr::MessageDescriptor Descriptor
-        {
-            get { return global::PokemonGo.RocketAPI.GeneratedCode.PayloadsReflection.Descriptor.MessageTypes[27]; }
-        }
-
-        public string Id
-        {
-            get { return id_; }
-            set { id_ = pb::ProtoPreconditions.CheckNotNull(value, "value"); }
-        }
-
-        public long LastModifiedTimestampMs
-        {
-            get { return lastModifiedTimestampMs_; }
-            set { lastModifiedTimestampMs_ = value; }
-        }
-
-        public double Latitude
-        {
-            get { return latitude_; }
-            set { latitude_ = value; }
-        }
-
-        public double Longitude
-        {
-            get { return longitude_; }
-            set { longitude_ = value; }
-        }
-
-        public bool Enabled
-        {
-            get { return enabled_; }
-            set { enabled_ = value; }
-        }
-
-        public global::PokemonGo.RocketAPI.GeneratedCode.FortType Type
-        {
-            get { return type_; }
-            set { type_ = value; }
-        }
-
-        /// <summary>
-        ///     Team that owns the gym
-        /// </summary>
-        public global::PokemonGo.RocketAPI.GeneratedCode.TeamColor OwnedByTeam
-        {
-            get { return ownedByTeam_; }
-            set { ownedByTeam_ = value; }
-        }
-
-        /// <summary>
-        ///     Highest CP Pokemon at the gym
-        /// </summary>
-        public global::PokemonGo.RocketAPI.GeneratedCode.PokemonId GuardPokemonId
-        {
-            get { return guardPokemonId_; }
-            set { guardPokemonId_ = value; }
-        }
-
-        public int GuardPokemonCp
-        {
-            get { return guardPokemonCp_; }
-            set { guardPokemonCp_ = value; }
-        }
-
-        /// <summary>
-        ///     Prestigate / experience of the gym
-        /// </summary>
-        public long GymPoints
-        {
-            get { return gymPoints_; }
-            set { gymPoints_ = value; }
-        }
-
-        /// <summary>
-        ///     Whether someone is battling at the gym currently
-        /// </summary>
-        public bool IsInBattle
-        {
-            get { return isInBattle_; }
-            set { isInBattle_ = value; }
-        }
-
-        /// <summary>
-        ///     Timestamp when the pokestop can be activated again to get items / xp
-        /// </summary>
-        public long CooldownCompleteTimestampMs
-        {
-            get { return cooldownCompleteTimestampMs_; }
-            set { cooldownCompleteTimestampMs_ = value; }
-        }
-
-        public global::PokemonGo.RocketAPI.GeneratedCode.FortSponsor Sponsor
-        {
-            get { return sponsor_; }
-            set { sponsor_ = value; }
-        }
-
-        public global::PokemonGo.RocketAPI.GeneratedCode.FortRenderingType RenderingType
-        {
-            get { return renderingType_; }
-            set { renderingType_ = value; }
-        }
-
-        /// <summary>
-        ///     Might represent the type of item applied to the pokestop, right now only lures can be applied
-        /// </summary>
-        public pb::ByteString ActiveFortModifier
-        {
-            get { return activeFortModifier_; }
-            set { activeFortModifier_ = pb::ProtoPreconditions.CheckNotNull(value, "value"); }
-        }
-
-        public global::PokemonGo.RocketAPI.GeneratedCode.FortLureInfo LureInfo
-        {
-            get { return lureInfo_; }
-            set { lureInfo_ = value; }
-        }
-
-        pbr::MessageDescriptor pb::IMessage.Descriptor
-        {
-            get { return Descriptor; }
-        }
-
-        public FortData Clone()
-        {
-            return new FortData(this);
-        }
-
-        public bool Equals(FortData other)
-        {
-            if (ReferenceEquals(other, null))
-            {
-                return false;
-            }
-            if (ReferenceEquals(other, this))
-            {
-                return true;
-            }
-            if (Id != other.Id) return false;
-            if (LastModifiedTimestampMs != other.LastModifiedTimestampMs) return false;
-            if (Latitude != other.Latitude) return false;
-            if (Longitude != other.Longitude) return false;
-            if (Enabled != other.Enabled) return false;
-            if (Type != other.Type) return false;
-            if (OwnedByTeam != other.OwnedByTeam) return false;
-            if (GuardPokemonId != other.GuardPokemonId) return false;
-            if (GuardPokemonCp != other.GuardPokemonCp) return false;
-            if (GymPoints != other.GymPoints) return false;
-            if (IsInBattle != other.IsInBattle) return false;
-            if (CooldownCompleteTimestampMs != other.CooldownCompleteTimestampMs) return false;
-            if (Sponsor != other.Sponsor) return false;
-            if (RenderingType != other.RenderingType) return false;
-            if (ActiveFortModifier != other.ActiveFortModifier) return false;
-            if (!Equals(LureInfo, other.LureInfo)) return false;
-            return true;
-        }
-
-        public void WriteTo(pb::CodedOutputStream output)
-        {
-            if (Id.Length != 0)
-            {
-                output.WriteRawTag(10);
-                output.WriteString(Id);
-            }
-            if (LastModifiedTimestampMs != 0L)
-            {
-                output.WriteRawTag(16);
-                output.WriteInt64(LastModifiedTimestampMs);
-            }
-            if (Latitude != 0D)
-            {
-                output.WriteRawTag(25);
-                output.WriteDouble(Latitude);
-            }
-            if (Longitude != 0D)
-            {
-                output.WriteRawTag(33);
-                output.WriteDouble(Longitude);
-            }
-            if (OwnedByTeam != 0)
-            {
-                output.WriteRawTag(40);
-                output.WriteEnum((int)OwnedByTeam);
-            }
-            if (GuardPokemonId != 0)
-            {
-                output.WriteRawTag(48);
-                output.WriteEnum((int)GuardPokemonId);
-            }
-            if (GuardPokemonCp != 0)
-            {
-                output.WriteRawTag(56);
-                output.WriteInt32(GuardPokemonCp);
-            }
-            if (Enabled != false)
-            {
-                output.WriteRawTag(64);
-                output.WriteBool(Enabled);
-            }
-            if (Type != 0)
-            {
-                output.WriteRawTag(72);
-                output.WriteEnum((int)Type);
-            }
-            if (GymPoints != 0L)
-            {
-                output.WriteRawTag(80);
-                output.WriteInt64(GymPoints);
-            }
-            if (IsInBattle != false)
-            {
-                output.WriteRawTag(88);
-                output.WriteBool(IsInBattle);
-            }
-            if (ActiveFortModifier.Length != 0)
-            {
-                output.WriteRawTag(98);
-                output.WriteBytes(ActiveFortModifier);
-            }
-            if (lureInfo_ != null)
-            {
-                output.WriteRawTag(106);
-                output.WriteMessage(LureInfo);
-            }
-            if (CooldownCompleteTimestampMs != 0L)
-            {
-                output.WriteRawTag(112);
-                output.WriteInt64(CooldownCompleteTimestampMs);
-            }
-            if (Sponsor != 0)
-            {
-                output.WriteRawTag(120);
-                output.WriteEnum((int)Sponsor);
-            }
-            if (RenderingType != 0)
-            {
-                output.WriteRawTag(128, 1);
-                output.WriteEnum((int)RenderingType);
-            }
-        }
-
-        public int CalculateSize()
-        {
-            var size = 0;
-            if (Id.Length != 0)
-            {
-                size += 1 + pb::CodedOutputStream.ComputeStringSize(Id);
-            }
-            if (LastModifiedTimestampMs != 0L)
-            {
-                size += 1 + pb::CodedOutputStream.ComputeInt64Size(LastModifiedTimestampMs);
-            }
-            if (Latitude != 0D)
-            {
-                size += 1 + 8;
-            }
-            if (Longitude != 0D)
-            {
-                size += 1 + 8;
-            }
-            if (Enabled != false)
-            {
-                size += 1 + 1;
-            }
-            if (Type != 0)
-            {
-                size += 1 + pb::CodedOutputStream.ComputeEnumSize((int)Type);
-            }
-            if (OwnedByTeam != 0)
-            {
-                size += 1 + pb::CodedOutputStream.ComputeEnumSize((int)OwnedByTeam);
-            }
-            if (GuardPokemonId != 0)
-            {
-                size += 1 + pb::CodedOutputStream.ComputeEnumSize((int)GuardPokemonId);
-            }
-            if (GuardPokemonCp != 0)
-            {
-                size += 1 + pb::CodedOutputStream.ComputeInt32Size(GuardPokemonCp);
-            }
-            if (GymPoints != 0L)
-            {
-                size += 1 + pb::CodedOutputStream.ComputeInt64Size(GymPoints);
-            }
-            if (IsInBattle != false)
-            {
-                size += 1 + 1;
-            }
-            if (CooldownCompleteTimestampMs != 0L)
-            {
-                size += 1 + pb::CodedOutputStream.ComputeInt64Size(CooldownCompleteTimestampMs);
-            }
-            if (Sponsor != 0)
-            {
-                size += 1 + pb::CodedOutputStream.ComputeEnumSize((int)Sponsor);
-            }
-            if (RenderingType != 0)
-            {
-                size += 2 + pb::CodedOutputStream.ComputeEnumSize((int)RenderingType);
-            }
-            if (ActiveFortModifier.Length != 0)
-            {
-                size += 1 + pb::CodedOutputStream.ComputeBytesSize(ActiveFortModifier);
-            }
-            if (lureInfo_ != null)
-            {
-                size += 1 + pb::CodedOutputStream.ComputeMessageSize(LureInfo);
-            }
-            return size;
-        }
-
-        public void MergeFrom(FortData other)
-        {
-            if (other == null)
-            {
-                return;
-            }
-            if (other.Id.Length != 0)
-            {
-                Id = other.Id;
-            }
-            if (other.LastModifiedTimestampMs != 0L)
-            {
-                LastModifiedTimestampMs = other.LastModifiedTimestampMs;
-            }
-            if (other.Latitude != 0D)
-            {
-                Latitude = other.Latitude;
-            }
-            if (other.Longitude != 0D)
-            {
-                Longitude = other.Longitude;
-            }
-            if (other.Enabled != false)
-            {
-                Enabled = other.Enabled;
-            }
-            if (other.Type != 0)
-            {
-                Type = other.Type;
-            }
-            if (other.OwnedByTeam != 0)
-            {
-                OwnedByTeam = other.OwnedByTeam;
-            }
-            if (other.GuardPokemonId != 0)
-            {
-                GuardPokemonId = other.GuardPokemonId;
-            }
-            if (other.GuardPokemonCp != 0)
-            {
-                GuardPokemonCp = other.GuardPokemonCp;
-            }
-            if (other.GymPoints != 0L)
-            {
-                GymPoints = other.GymPoints;
-            }
-            if (other.IsInBattle != false)
-            {
-                IsInBattle = other.IsInBattle;
-            }
-            if (other.CooldownCompleteTimestampMs != 0L)
-            {
-                CooldownCompleteTimestampMs = other.CooldownCompleteTimestampMs;
-            }
-            if (other.Sponsor != 0)
-            {
-                Sponsor = other.Sponsor;
-            }
-            if (other.RenderingType != 0)
-            {
-                RenderingType = other.RenderingType;
-            }
-            if (other.ActiveFortModifier.Length != 0)
-            {
-                ActiveFortModifier = other.ActiveFortModifier;
-            }
-            if (other.lureInfo_ != null)
-            {
-                if (lureInfo_ == null)
-                {
-                    lureInfo_ = new global::PokemonGo.RocketAPI.GeneratedCode.FortLureInfo();
-                }
-                LureInfo.MergeFrom(other.LureInfo);
-            }
-        }
-
-        public void MergeFrom(pb::CodedInputStream input)
-        {
-            uint tag;
-            while ((tag = input.ReadTag()) != 0)
-            {
-                switch (tag)
-                {
-                    default:
-                        input.SkipLastField();
-                        break;
-                    case 10:
-                        {
-                            Id = input.ReadString();
-                            break;
-                        }
-                    case 16:
-                        {
-                            LastModifiedTimestampMs = input.ReadInt64();
-                            break;
-                        }
-                    case 25:
-                        {
-                            Latitude = input.ReadDouble();
-                            break;
-                        }
-                    case 33:
-                        {
-                            Longitude = input.ReadDouble();
-                            break;
-                        }
-                    case 40:
-                        {
-                            ownedByTeam_ = (global::PokemonGo.RocketAPI.GeneratedCode.TeamColor)input.ReadEnum();
-                            break;
-                        }
-                    case 48:
-                        {
-                            guardPokemonId_ = (global::PokemonGo.RocketAPI.GeneratedCode.PokemonId)input.ReadEnum();
-                            break;
-                        }
-                    case 56:
-                        {
-                            GuardPokemonCp = input.ReadInt32();
-                            break;
-                        }
-                    case 64:
-                        {
-                            Enabled = input.ReadBool();
-                            break;
-                        }
-                    case 72:
-                        {
-                            type_ = (global::PokemonGo.RocketAPI.GeneratedCode.FortType)input.ReadEnum();
-                            break;
-                        }
-                    case 80:
-                        {
-                            GymPoints = input.ReadInt64();
-                            break;
-                        }
-                    case 88:
-                        {
-                            IsInBattle = input.ReadBool();
-                            break;
-                        }
-                    case 98:
-                        {
-                            ActiveFortModifier = input.ReadBytes();
-                            break;
-                        }
-                    case 106:
-                        {
-                            if (lureInfo_ == null)
-                            {
-                                lureInfo_ = new global::PokemonGo.RocketAPI.GeneratedCode.FortLureInfo();
-                            }
-                            input.ReadMessage(lureInfo_);
-                            break;
-                        }
-                    case 112:
-                        {
-                            CooldownCompleteTimestampMs = input.ReadInt64();
-                            break;
-                        }
-                    case 120:
-                        {
-                            sponsor_ = (global::PokemonGo.RocketAPI.GeneratedCode.FortSponsor)input.ReadEnum();
-                            break;
-                        }
-                    case 128:
-                        {
-                            renderingType_ = (global::PokemonGo.RocketAPI.GeneratedCode.FortRenderingType)input.ReadEnum();
-                            break;
-                        }
-                }
-            }
-        }
-
-        public override bool Equals(object other)
-        {
-            return Equals(other as FortData);
-        }
-
-        public override int GetHashCode()
-        {
-            var hash = 1;
-            if (Id.Length != 0) hash ^= Id.GetHashCode();
-            if (LastModifiedTimestampMs != 0L) hash ^= LastModifiedTimestampMs.GetHashCode();
-            if (Latitude != 0D) hash ^= Latitude.GetHashCode();
-            if (Longitude != 0D) hash ^= Longitude.GetHashCode();
-            if (Enabled != false) hash ^= Enabled.GetHashCode();
-            if (Type != 0) hash ^= Type.GetHashCode();
-            if (OwnedByTeam != 0) hash ^= OwnedByTeam.GetHashCode();
-            if (GuardPokemonId != 0) hash ^= GuardPokemonId.GetHashCode();
-            if (GuardPokemonCp != 0) hash ^= GuardPokemonCp.GetHashCode();
-            if (GymPoints != 0L) hash ^= GymPoints.GetHashCode();
-            if (IsInBattle != false) hash ^= IsInBattle.GetHashCode();
-            if (CooldownCompleteTimestampMs != 0L) hash ^= CooldownCompleteTimestampMs.GetHashCode();
-            if (Sponsor != 0) hash ^= Sponsor.GetHashCode();
-            if (RenderingType != 0) hash ^= RenderingType.GetHashCode();
-            if (ActiveFortModifier.Length != 0) hash ^= ActiveFortModifier.GetHashCode();
-            if (lureInfo_ != null) hash ^= LureInfo.GetHashCode();
-            return hash;
-        }
-
-        partial void OnConstruction();
-
-        public override string ToString()
-        {
-            return pb::JsonFormatter.ToDiagnosticString(this);
-        }
-    }
-
-    [global::System.Diagnostics.DebuggerNonUserCodeAttribute()]
-    public sealed partial class FortLureInfo : pb::IMessage<FortLureInfo>
-    {
-        /// <summary>Field number for the "fort_id" field.</summary>
-        public const int FortIdFieldNumber = 1;
-
-        /// <summary>Field number for the "unknown2" field.</summary>
-        public const int Unknown2FieldNumber = 2;
-
-        /// <summary>Field number for the "active_pokemon_id" field.</summary>
-        public const int ActivePokemonIdFieldNumber = 3;
-
-        /// <summary>Field number for the "lure_expires_timestamp_ms" field.</summary>
-        public const int LureExpiresTimestampMsFieldNumber = 4;
-
-        private static readonly pb::MessageParser<FortLureInfo> _parser =
-            new pb::MessageParser<FortLureInfo>(() => new FortLureInfo());
-
-        private global::PokemonGo.RocketAPI.GeneratedCode.PokemonId activePokemonId_ = 0;
-        private string fortId_ = "";
-        private long lureExpiresTimestampMs_;
-        private double unknown2_;
-
-        public FortLureInfo()
-        {
-            OnConstruction();
-        }
-
-        public FortLureInfo(FortLureInfo other) : this()
-        {
-            fortId_ = other.fortId_;
-            unknown2_ = other.unknown2_;
-            activePokemonId_ = other.activePokemonId_;
-            lureExpiresTimestampMs_ = other.lureExpiresTimestampMs_;
-        }
-
-        public static pb::MessageParser<FortLureInfo> Parser
-        {
-            get { return _parser; }
-        }
-
-        public static pbr::MessageDescriptor Descriptor
-        {
-            get { return global::PokemonGo.RocketAPI.GeneratedCode.PayloadsReflection.Descriptor.MessageTypes[28]; }
-        }
-
-        public string FortId
-        {
-            get { return fortId_; }
-            set { fortId_ = pb::ProtoPreconditions.CheckNotNull(value, "value"); }
-        }
-
-        public double Unknown2
-        {
-            get { return unknown2_; }
-            set { unknown2_ = value; }
-        }
-
-        public global::PokemonGo.RocketAPI.GeneratedCode.PokemonId ActivePokemonId
-        {
-            get { return activePokemonId_; }
-            set { activePokemonId_ = value; }
-        }
-
-        public long LureExpiresTimestampMs
-        {
-            get { return lureExpiresTimestampMs_; }
-            set { lureExpiresTimestampMs_ = value; }
-        }
-
-        pbr::MessageDescriptor pb::IMessage.Descriptor
-        {
-            get { return Descriptor; }
-        }
-
-        public FortLureInfo Clone()
-        {
-            return new FortLureInfo(this);
-        }
-
-        public bool Equals(FortLureInfo other)
-        {
-            if (ReferenceEquals(other, null))
-            {
-                return false;
-            }
-            if (ReferenceEquals(other, this))
-            {
-                return true;
-            }
-            if (FortId != other.FortId) return false;
-            if (Unknown2 != other.Unknown2) return false;
-            if (ActivePokemonId != other.ActivePokemonId) return false;
-            if (LureExpiresTimestampMs != other.LureExpiresTimestampMs) return false;
-            return true;
-        }
-
-        public void WriteTo(pb::CodedOutputStream output)
-        {
-            if (FortId.Length != 0)
-            {
-                output.WriteRawTag(10);
-                output.WriteString(FortId);
-            }
-            if (Unknown2 != 0D)
-            {
-                output.WriteRawTag(17);
-                output.WriteDouble(Unknown2);
-            }
-            if (ActivePokemonId != 0)
-            {
-                output.WriteRawTag(24);
-                output.WriteEnum((int)ActivePokemonId);
-            }
-            if (LureExpiresTimestampMs != 0L)
-            {
-                output.WriteRawTag(32);
-                output.WriteInt64(LureExpiresTimestampMs);
-            }
-        }
-
-        public int CalculateSize()
-        {
-            var size = 0;
-            if (FortId.Length != 0)
-            {
-                size += 1 + pb::CodedOutputStream.ComputeStringSize(FortId);
-            }
-            if (Unknown2 != 0D)
-            {
-                size += 1 + 8;
-            }
-            if (ActivePokemonId != 0)
-            {
-                size += 1 + pb::CodedOutputStream.ComputeEnumSize((int)ActivePokemonId);
-            }
-            if (LureExpiresTimestampMs != 0L)
-            {
-                size += 1 + pb::CodedOutputStream.ComputeInt64Size(LureExpiresTimestampMs);
-            }
-            return size;
-        }
-
-        public void MergeFrom(FortLureInfo other)
-        {
-            if (other == null)
-            {
-                return;
-            }
-            if (other.FortId.Length != 0)
-            {
-                FortId = other.FortId;
-            }
-            if (other.Unknown2 != 0D)
-            {
-                Unknown2 = other.Unknown2;
-            }
-            if (other.ActivePokemonId != 0)
-            {
-                ActivePokemonId = other.ActivePokemonId;
-            }
-            if (other.LureExpiresTimestampMs != 0L)
-            {
-                LureExpiresTimestampMs = other.LureExpiresTimestampMs;
-            }
-        }
-
-        public void MergeFrom(pb::CodedInputStream input)
-        {
-            uint tag;
-            while ((tag = input.ReadTag()) != 0)
-            {
-                switch (tag)
-                {
-                    default:
-                        input.SkipLastField();
-                        break;
-                    case 10:
-                        {
-                            FortId = input.ReadString();
-                            break;
-                        }
-                    case 17:
-                        {
-                            Unknown2 = input.ReadDouble();
-                            break;
-                        }
-                    case 24:
-                        {
-                            activePokemonId_ = (global::PokemonGo.RocketAPI.GeneratedCode.PokemonId)input.ReadEnum();
-                            break;
-                        }
-                    case 32:
-                        {
-                            LureExpiresTimestampMs = input.ReadInt64();
-                            break;
-                        }
-                }
-            }
-        }
-
-        public override bool Equals(object other)
-        {
-            return Equals(other as FortLureInfo);
-        }
-
-        public override int GetHashCode()
-        {
-            var hash = 1;
-            if (FortId.Length != 0) hash ^= FortId.GetHashCode();
-            if (Unknown2 != 0D) hash ^= Unknown2.GetHashCode();
-            if (ActivePokemonId != 0) hash ^= ActivePokemonId.GetHashCode();
-            if (LureExpiresTimestampMs != 0L) hash ^= LureExpiresTimestampMs.GetHashCode();
-            return hash;
-        }
-
-        partial void OnConstruction();
-
-        public override string ToString()
-        {
-            return pb::JsonFormatter.ToDiagnosticString(this);
-        }
-    }
-
-    [global::System.Diagnostics.DebuggerNonUserCodeAttribute()]
-    public sealed partial class SpawnPoint : pb::IMessage<SpawnPoint>
-    {
-        /// <summary>Field number for the "latitude" field.</summary>
-        public const int LatitudeFieldNumber = 2;
-
-        /// <summary>Field number for the "longitude" field.</summary>
-        public const int LongitudeFieldNumber = 3;
-
-        private static readonly pb::MessageParser<SpawnPoint> _parser =
-            new pb::MessageParser<SpawnPoint>(() => new SpawnPoint());
-
-        private double latitude_;
-        private double longitude_;
-
-        public SpawnPoint()
-        {
-            OnConstruction();
-        }
-
-        public SpawnPoint(SpawnPoint other) : this()
-        {
-            latitude_ = other.latitude_;
-            longitude_ = other.longitude_;
-        }
-
-        public static pb::MessageParser<SpawnPoint> Parser
-        {
-            get { return _parser; }
-        }
-
-        public static pbr::MessageDescriptor Descriptor
-        {
-            get { return global::PokemonGo.RocketAPI.GeneratedCode.PayloadsReflection.Descriptor.MessageTypes[29]; }
-        }
-
-        public double Latitude
-        {
-            get { return latitude_; }
-            set { latitude_ = value; }
-        }
-
-        public double Longitude
-        {
-            get { return longitude_; }
-            set { longitude_ = value; }
-        }
-
-        pbr::MessageDescriptor pb::IMessage.Descriptor
-        {
-            get { return Descriptor; }
-        }
-
-        public SpawnPoint Clone()
-        {
-            return new SpawnPoint(this);
-        }
-
-        public bool Equals(SpawnPoint other)
-        {
-            if (ReferenceEquals(other, null))
-            {
-                return false;
-            }
-            if (ReferenceEquals(other, this))
-            {
-                return true;
-            }
-            if (Latitude != other.Latitude) return false;
-            if (Longitude != other.Longitude) return false;
-            return true;
-        }
-
-        public void WriteTo(pb::CodedOutputStream output)
-        {
-            if (Latitude != 0D)
-            {
-                output.WriteRawTag(17);
-                output.WriteDouble(Latitude);
-            }
-            if (Longitude != 0D)
-            {
-                output.WriteRawTag(25);
-                output.WriteDouble(Longitude);
-            }
-        }
-
-        public int CalculateSize()
-        {
-            var size = 0;
-            if (Latitude != 0D)
-            {
-                size += 1 + 8;
-            }
-            if (Longitude != 0D)
-            {
-                size += 1 + 8;
-            }
-            return size;
-        }
-
-        public void MergeFrom(SpawnPoint other)
-        {
-            if (other == null)
-            {
-                return;
-            }
-            if (other.Latitude != 0D)
-            {
-                Latitude = other.Latitude;
-            }
-            if (other.Longitude != 0D)
-            {
-                Longitude = other.Longitude;
-            }
-        }
-
-        public void MergeFrom(pb::CodedInputStream input)
-        {
-            uint tag;
-            while ((tag = input.ReadTag()) != 0)
-            {
-                switch (tag)
-                {
-                    default:
-                        input.SkipLastField();
-                        break;
-                    case 17:
-                        {
-                            Latitude = input.ReadDouble();
-                            break;
-                        }
-                    case 25:
-                        {
-                            Longitude = input.ReadDouble();
-                            break;
-                        }
-                }
-            }
-        }
-
-        public override bool Equals(object other)
-        {
-            return Equals(other as SpawnPoint);
-        }
-
-        public override int GetHashCode()
-        {
-            var hash = 1;
-            if (Latitude != 0D) hash ^= Latitude.GetHashCode();
-            if (Longitude != 0D) hash ^= Longitude.GetHashCode();
-            return hash;
-        }
-
-        partial void OnConstruction();
-
-        public override string ToString()
-        {
-            return pb::JsonFormatter.ToDiagnosticString(this);
-        }
-    }
-
-    [global::System.Diagnostics.DebuggerNonUserCodeAttribute()]
-    public sealed partial class FortSummary : pb::IMessage<FortSummary>
-    {
-        /// <summary>Field number for the "fort_summary_id" field.</summary>
-        public const int FortSummaryIdFieldNumber = 1;
-
-        /// <summary>Field number for the "last_modified_timestamp_ms" field.</summary>
-        public const int LastModifiedTimestampMsFieldNumber = 2;
-
-        /// <summary>Field number for the "latitude" field.</summary>
-        public const int LatitudeFieldNumber = 3;
-
-        /// <summary>Field number for the "longitude" field.</summary>
-        public const int LongitudeFieldNumber = 4;
-
-        private static readonly pb::MessageParser<FortSummary> _parser =
-            new pb::MessageParser<FortSummary>(() => new FortSummary());
-
-        private int fortSummaryId_;
-        private int lastModifiedTimestampMs_;
-        private int latitude_;
-        private int longitude_;
-
-        public FortSummary()
-        {
-            OnConstruction();
-        }
-
-        public FortSummary(FortSummary other) : this()
-        {
-            fortSummaryId_ = other.fortSummaryId_;
-            lastModifiedTimestampMs_ = other.lastModifiedTimestampMs_;
-            latitude_ = other.latitude_;
-            longitude_ = other.longitude_;
-        }
-
-        public static pb::MessageParser<FortSummary> Parser
-        {
-            get { return _parser; }
-        }
-
-        public static pbr::MessageDescriptor Descriptor
-        {
-            get { return global::PokemonGo.RocketAPI.GeneratedCode.PayloadsReflection.Descriptor.MessageTypes[30]; }
-        }
-
-        public int FortSummaryId
-        {
-            get { return fortSummaryId_; }
-            set { fortSummaryId_ = value; }
-        }
-
-        public int LastModifiedTimestampMs
-        {
-            get { return lastModifiedTimestampMs_; }
-            set { lastModifiedTimestampMs_ = value; }
-        }
-
-        public int Latitude
-        {
-            get { return latitude_; }
-            set { latitude_ = value; }
-        }
-
-        public int Longitude
-        {
-            get { return longitude_; }
-            set { longitude_ = value; }
-        }
-
-        pbr::MessageDescriptor pb::IMessage.Descriptor
-        {
-            get { return Descriptor; }
-        }
-
-        public FortSummary Clone()
-        {
-            return new FortSummary(this);
-        }
-
-        public bool Equals(FortSummary other)
-        {
-            if (ReferenceEquals(other, null))
-            {
-                return false;
-            }
-            if (ReferenceEquals(other, this))
-            {
-                return true;
-            }
-            if (FortSummaryId != other.FortSummaryId) return false;
-            if (LastModifiedTimestampMs != other.LastModifiedTimestampMs) return false;
-            if (Latitude != other.Latitude) return false;
-            if (Longitude != other.Longitude) return false;
-            return true;
-        }
-
-        public void WriteTo(pb::CodedOutputStream output)
-        {
-            if (FortSummaryId != 0)
-            {
-                output.WriteRawTag(8);
-                output.WriteInt32(FortSummaryId);
-            }
-            if (LastModifiedTimestampMs != 0)
-            {
-                output.WriteRawTag(16);
-                output.WriteInt32(LastModifiedTimestampMs);
-            }
-            if (Latitude != 0)
-            {
-                output.WriteRawTag(24);
-                output.WriteInt32(Latitude);
-            }
-            if (Longitude != 0)
-            {
-                output.WriteRawTag(32);
-                output.WriteInt32(Longitude);
-            }
-        }
-
-        public int CalculateSize()
-        {
-            var size = 0;
-            if (FortSummaryId != 0)
-            {
-                size += 1 + pb::CodedOutputStream.ComputeInt32Size(FortSummaryId);
-            }
-            if (LastModifiedTimestampMs != 0)
-            {
-                size += 1 + pb::CodedOutputStream.ComputeInt32Size(LastModifiedTimestampMs);
-            }
-            if (Latitude != 0)
-            {
-                size += 1 + pb::CodedOutputStream.ComputeInt32Size(Latitude);
-            }
-            if (Longitude != 0)
-            {
-                size += 1 + pb::CodedOutputStream.ComputeInt32Size(Longitude);
-            }
-            return size;
-        }
-
-        public void MergeFrom(FortSummary other)
-        {
-            if (other == null)
-            {
-                return;
-            }
-            if (other.FortSummaryId != 0)
-            {
-                FortSummaryId = other.FortSummaryId;
-            }
-            if (other.LastModifiedTimestampMs != 0)
-            {
-                LastModifiedTimestampMs = other.LastModifiedTimestampMs;
-            }
-            if (other.Latitude != 0)
-            {
-                Latitude = other.Latitude;
-            }
-            if (other.Longitude != 0)
-            {
-                Longitude = other.Longitude;
-            }
-        }
-
-        public void MergeFrom(pb::CodedInputStream input)
-        {
-            uint tag;
-            while ((tag = input.ReadTag()) != 0)
-            {
-                switch (tag)
-                {
-                    default:
-                        input.SkipLastField();
-                        break;
-                    case 8:
-                        {
-                            FortSummaryId = input.ReadInt32();
-                            break;
-                        }
-                    case 16:
-                        {
-                            LastModifiedTimestampMs = input.ReadInt32();
-                            break;
-                        }
-                    case 24:
-                        {
-                            Latitude = input.ReadInt32();
-                            break;
-                        }
-                    case 32:
-                        {
-                            Longitude = input.ReadInt32();
-                            break;
-                        }
-                }
-            }
-        }
-
-        public override bool Equals(object other)
-        {
-            return Equals(other as FortSummary);
-        }
-
-        public override int GetHashCode()
-        {
-            var hash = 1;
-            if (FortSummaryId != 0) hash ^= FortSummaryId.GetHashCode();
-            if (LastModifiedTimestampMs != 0) hash ^= LastModifiedTimestampMs.GetHashCode();
-            if (Latitude != 0) hash ^= Latitude.GetHashCode();
-            if (Longitude != 0) hash ^= Longitude.GetHashCode();
-            return hash;
-        }
-
-        partial void OnConstruction();
-
-        public override string ToString()
-        {
-            return pb::JsonFormatter.ToDiagnosticString(this);
-        }
-    }
-
-    [global::System.Diagnostics.DebuggerNonUserCodeAttribute()]
-    public sealed partial class WildPokemon : pb::IMessage<WildPokemon>
-    {
-        /// <summary>Field number for the "encounter_id" field.</summary>
-        public const int EncounterIdFieldNumber = 1;
-
-        /// <summary>Field number for the "last_modified_timestamp_ms" field.</summary>
-        public const int LastModifiedTimestampMsFieldNumber = 2;
-
-        /// <summary>Field number for the "latitude" field.</summary>
-        public const int LatitudeFieldNumber = 3;
-
-        /// <summary>Field number for the "longitude" field.</summary>
-        public const int LongitudeFieldNumber = 4;
-
-        /// <summary>Field number for the "spawnpoint_id" field.</summary>
-        public const int SpawnpointIdFieldNumber = 5;
-
-        /// <summary>Field number for the "pokemon_data" field.</summary>
-        public const int PokemonDataFieldNumber = 7;
-
-        /// <summary>Field number for the "time_till_hidden_ms" field.</summary>
-        public const int TimeTillHiddenMsFieldNumber = 11;
-
-        private static readonly pb::MessageParser<WildPokemon> _parser =
-            new pb::MessageParser<WildPokemon>(() => new WildPokemon());
-
-        private ulong encounterId_;
-        private long lastModifiedTimestampMs_;
-        private double latitude_;
-        private double longitude_;
-        private global::PokemonGo.RocketAPI.GeneratedCode.PokemonData pokemonData_;
-        private string spawnpointId_ = "";
-        private int timeTillHiddenMs_;
-
-        public WildPokemon()
-        {
-            OnConstruction();
-        }
-
-        public WildPokemon(WildPokemon other) : this()
-        {
-            encounterId_ = other.encounterId_;
-            lastModifiedTimestampMs_ = other.lastModifiedTimestampMs_;
-            latitude_ = other.latitude_;
-            longitude_ = other.longitude_;
-            spawnpointId_ = other.spawnpointId_;
-            PokemonData = other.pokemonData_ != null ? other.PokemonData.Clone() : null;
-            timeTillHiddenMs_ = other.timeTillHiddenMs_;
-        }
-
-        public static pb::MessageParser<WildPokemon> Parser
-        {
-            get { return _parser; }
-        }
-
-        public static pbr::MessageDescriptor Descriptor
-        {
-            get { return global::PokemonGo.RocketAPI.GeneratedCode.PayloadsReflection.Descriptor.MessageTypes[31]; }
-        }
-
-        public ulong EncounterId
-        {
-            get { return encounterId_; }
-            set { encounterId_ = value; }
-        }
-
-        public long LastModifiedTimestampMs
-        {
-            get { return lastModifiedTimestampMs_; }
-            set { lastModifiedTimestampMs_ = value; }
-        }
-
-        public double Latitude
-        {
-            get { return latitude_; }
-            set { latitude_ = value; }
-        }
-
-        public double Longitude
-        {
-            get { return longitude_; }
-            set { longitude_ = value; }
-        }
-
-        public string SpawnpointId
-        {
-            get { return spawnpointId_; }
-            set { spawnpointId_ = pb::ProtoPreconditions.CheckNotNull(value, "value"); }
-        }
-
-        public global::PokemonGo.RocketAPI.GeneratedCode.PokemonData PokemonData
-        {
-            get { return pokemonData_; }
-            set { pokemonData_ = value; }
-        }
-
-        public int TimeTillHiddenMs
-        {
-            get { return timeTillHiddenMs_; }
-            set { timeTillHiddenMs_ = value; }
-        }
-
-        pbr::MessageDescriptor pb::IMessage.Descriptor
-        {
-            get { return Descriptor; }
-        }
-
-        public WildPokemon Clone()
-        {
-            return new WildPokemon(this);
-        }
-
-        public bool Equals(WildPokemon other)
-        {
-            if (ReferenceEquals(other, null))
-            {
-                return false;
-            }
-            if (ReferenceEquals(other, this))
-            {
-                return true;
-            }
-            if (EncounterId != other.EncounterId) return false;
-            if (LastModifiedTimestampMs != other.LastModifiedTimestampMs) return false;
-            if (Latitude != other.Latitude) return false;
-            if (Longitude != other.Longitude) return false;
-            if (SpawnpointId != other.SpawnpointId) return false;
-            if (!Equals(PokemonData, other.PokemonData)) return false;
-            if (TimeTillHiddenMs != other.TimeTillHiddenMs) return false;
-            return true;
-        }
-
-        public void WriteTo(pb::CodedOutputStream output)
-        {
-            if (EncounterId != 0UL)
-            {
-                output.WriteRawTag(9);
-                output.WriteFixed64(EncounterId);
-            }
-            if (LastModifiedTimestampMs != 0L)
-            {
-                output.WriteRawTag(16);
-                output.WriteInt64(LastModifiedTimestampMs);
-            }
-            if (Latitude != 0D)
-            {
-                output.WriteRawTag(25);
-                output.WriteDouble(Latitude);
-            }
-            if (Longitude != 0D)
-            {
-                output.WriteRawTag(33);
-                output.WriteDouble(Longitude);
-            }
-            if (SpawnpointId.Length != 0)
-            {
-                output.WriteRawTag(42);
-                output.WriteString(SpawnpointId);
-            }
-            if (pokemonData_ != null)
-            {
-                output.WriteRawTag(58);
-                output.WriteMessage(PokemonData);
-            }
-            if (TimeTillHiddenMs != 0)
-            {
-                output.WriteRawTag(88);
-                output.WriteInt32(TimeTillHiddenMs);
-            }
-        }
-
-        public int CalculateSize()
-        {
-            var size = 0;
-            if (EncounterId != 0UL)
-            {
-                size += 1 + 8;
-            }
-            if (LastModifiedTimestampMs != 0L)
-            {
-                size += 1 + pb::CodedOutputStream.ComputeInt64Size(LastModifiedTimestampMs);
-            }
-            if (Latitude != 0D)
-            {
-                size += 1 + 8;
-            }
-            if (Longitude != 0D)
-            {
-                size += 1 + 8;
-            }
-            if (SpawnpointId.Length != 0)
-            {
-                size += 1 + pb::CodedOutputStream.ComputeStringSize(SpawnpointId);
-            }
-            if (pokemonData_ != null)
-            {
-                size += 1 + pb::CodedOutputStream.ComputeMessageSize(PokemonData);
-            }
-            if (TimeTillHiddenMs != 0)
-            {
-                size += 1 + pb::CodedOutputStream.ComputeInt32Size(TimeTillHiddenMs);
-            }
-            return size;
-        }
-
-        public void MergeFrom(WildPokemon other)
-        {
-            if (other == null)
-            {
-                return;
-            }
-            if (other.EncounterId != 0UL)
-            {
-                EncounterId = other.EncounterId;
-            }
-            if (other.LastModifiedTimestampMs != 0L)
-            {
-                LastModifiedTimestampMs = other.LastModifiedTimestampMs;
-            }
-            if (other.Latitude != 0D)
-            {
-                Latitude = other.Latitude;
-            }
-            if (other.Longitude != 0D)
-            {
-                Longitude = other.Longitude;
-            }
-            if (other.SpawnpointId.Length != 0)
-            {
-                SpawnpointId = other.SpawnpointId;
-            }
-            if (other.pokemonData_ != null)
-            {
-                if (pokemonData_ == null)
-                {
-                    pokemonData_ = new global::PokemonGo.RocketAPI.GeneratedCode.PokemonData();
-                }
-                PokemonData.MergeFrom(other.PokemonData);
-            }
-            if (other.TimeTillHiddenMs != 0)
-            {
-                TimeTillHiddenMs = other.TimeTillHiddenMs;
-            }
-        }
-
-        public void MergeFrom(pb::CodedInputStream input)
-        {
-            uint tag;
-            while ((tag = input.ReadTag()) != 0)
-            {
-                switch (tag)
-                {
-                    default:
-                        input.SkipLastField();
-                        break;
-                    case 9:
-                        {
-                            EncounterId = input.ReadFixed64();
-                            break;
-                        }
-                    case 16:
-                        {
-                            LastModifiedTimestampMs = input.ReadInt64();
-                            break;
-                        }
-                    case 25:
-                        {
-                            Latitude = input.ReadDouble();
-                            break;
-                        }
-                    case 33:
-                        {
-                            Longitude = input.ReadDouble();
-                            break;
-                        }
-                    case 42:
-                        {
-                            SpawnpointId = input.ReadString();
-                            break;
-                        }
-                    case 58:
-                        {
-                            if (pokemonData_ == null)
-                            {
-                                pokemonData_ = new global::PokemonGo.RocketAPI.GeneratedCode.PokemonData();
-                            }
-                            input.ReadMessage(pokemonData_);
-                            break;
-                        }
-                    case 88:
-                        {
-                            TimeTillHiddenMs = input.ReadInt32();
-                            break;
-                        }
-                }
-            }
-        }
-
-        public override bool Equals(object other)
-        {
-            return Equals(other as WildPokemon);
-        }
-
-        public override int GetHashCode()
-        {
-            var hash = 1;
-            if (EncounterId != 0UL) hash ^= EncounterId.GetHashCode();
-            if (LastModifiedTimestampMs != 0L) hash ^= LastModifiedTimestampMs.GetHashCode();
-            if (Latitude != 0D) hash ^= Latitude.GetHashCode();
-            if (Longitude != 0D) hash ^= Longitude.GetHashCode();
-            if (SpawnpointId.Length != 0) hash ^= SpawnpointId.GetHashCode();
-            if (pokemonData_ != null) hash ^= PokemonData.GetHashCode();
-            if (TimeTillHiddenMs != 0) hash ^= TimeTillHiddenMs.GetHashCode();
-            return hash;
-        }
-
-        partial void OnConstruction();
-
-        public override string ToString()
-        {
-            return pb::JsonFormatter.ToDiagnosticString(this);
-        }
-    }
-
-    [global::System.Diagnostics.DebuggerNonUserCodeAttribute()]
-    public sealed partial class PokemonData : pb::IMessage<PokemonData>
-    {
-        /// <summary>Field number for the "id" field.</summary>
-        public const int IdFieldNumber = 1;
-
-        /// <summary>Field number for the "pokemon_id" field.</summary>
-        public const int PokemonIdFieldNumber = 2;
-
-        /// <summary>Field number for the "cp" field.</summary>
-        public const int CpFieldNumber = 3;
-
-        /// <summary>Field number for the "stamina" field.</summary>
-        public const int StaminaFieldNumber = 4;
-
-        /// <summary>Field number for the "stamina_max" field.</summary>
-        public const int StaminaMaxFieldNumber = 5;
-
-        /// <summary>Field number for the "move_1" field.</summary>
-        public const int Move1FieldNumber = 6;
-
-        /// <summary>Field number for the "move_2" field.</summary>
-        public const int Move2FieldNumber = 7;
-
-        /// <summary>Field number for the "deployed_fort_id" field.</summary>
-        public const int DeployedFortIdFieldNumber = 8;
-
-        /// <summary>Field number for the "owner_name" field.</summary>
-        public const int OwnerNameFieldNumber = 9;
-
-        /// <summary>Field number for the "is_egg" field.</summary>
-        public const int IsEggFieldNumber = 10;
-
-        /// <summary>Field number for the "egg_km_walked_target" field.</summary>
-        public const int EggKmWalkedTargetFieldNumber = 11;
-
-        /// <summary>Field number for the "egg_km_walked_start" field.</summary>
-        public const int EggKmWalkedStartFieldNumber = 12;
-
-        /// <summary>Field number for the "origin" field.</summary>
-        public const int OriginFieldNumber = 14;
-
-        /// <summary>Field number for the "height_m" field.</summary>
-        public const int HeightMFieldNumber = 15;
-
-        /// <summary>Field number for the "weight_kg" field.</summary>
-        public const int WeightKgFieldNumber = 16;
-
-        /// <summary>Field number for the "individual_attack" field.</summary>
-        public const int IndividualAttackFieldNumber = 17;
-
-        /// <summary>Field number for the "individual_defense" field.</summary>
-        public const int IndividualDefenseFieldNumber = 18;
-
-        /// <summary>Field number for the "individual_stamina" field.</summary>
-        public const int IndividualStaminaFieldNumber = 19;
-
-        /// <summary>Field number for the "cp_multiplier" field.</summary>
-        public const int CpMultiplierFieldNumber = 20;
-
-        /// <summary>Field number for the "pokeball" field.</summary>
-        public const int PokeballFieldNumber = 21;
-
-        /// <summary>Field number for the "captured_cell_id" field.</summary>
-        public const int CapturedCellIdFieldNumber = 22;
-
-        /// <summary>Field number for the "battles_attacked" field.</summary>
-        public const int BattlesAttackedFieldNumber = 23;
-
-        /// <summary>Field number for the "battles_defended" field.</summary>
-        public const int BattlesDefendedFieldNumber = 24;
-
-        /// <summary>Field number for the "egg_incubator_id" field.</summary>
-        public const int EggIncubatorIdFieldNumber = 25;
-
-        /// <summary>Field number for the "creation_time_ms" field.</summary>
-        public const int CreationTimeMsFieldNumber = 26;
-
-        /// <summary>Field number for the "num_upgrades" field.</summary>
-        public const int NumUpgradesFieldNumber = 27;
-
-        /// <summary>Field number for the "additional_cp_multiplier" field.</summary>
-        public const int AdditionalCpMultiplierFieldNumber = 28;
-
-        /// <summary>Field number for the "favorite" field.</summary>
-        public const int FavoriteFieldNumber = 29;
-
-        /// <summary>Field number for the "nickname" field.</summary>
-        public const int NicknameFieldNumber = 30;
-
-        /// <summary>Field number for the "from_fort" field.</summary>
-        public const int FromFortFieldNumber = 31;
-
-        private static readonly pb::MessageParser<PokemonData> _parser =
-            new pb::MessageParser<PokemonData>(() => new PokemonData());
-
-        private float additionalCpMultiplier_;
-        private int battlesAttacked_;
-        private int battlesDefended_;
-        private ulong capturedCellId_;
-        private int cp_;
-        private float cpMultiplier_;
-        private ulong creationTimeMs_;
-        private int deployedFortId_;
-        private int eggIncubatorId_;
-        private int eggKmWalkedStart_;
-        private int eggKmWalkedTarget_;
-        private int favorite_;
-        private int fromFort_;
-        private float heightM_;
-        private ulong id_;
-        private int individualAttack_;
-        private int individualDefense_;
-        private int individualStamina_;
-        private bool isEgg_;
-        private global::PokemonGo.RocketAPI.GeneratedCode.PokemonMove move1_ = 0;
-        private global::PokemonGo.RocketAPI.GeneratedCode.PokemonMove move2_ = 0;
-        private string nickname_ = "";
-        private int numUpgrades_;
-        private int origin_;
-        private string ownerName_ = "";
-        private int pokeball_;
-        private global::PokemonGo.RocketAPI.GeneratedCode.PokemonId pokemonId_ = 0;
-        private int stamina_;
-        private int staminaMax_;
-        private float weightKg_;
-
-        public PokemonData()
-        {
-            OnConstruction();
-        }
-
-        public PokemonData(PokemonData other) : this()
-        {
-            id_ = other.id_;
-            pokemonId_ = other.pokemonId_;
-            cp_ = other.cp_;
-            stamina_ = other.stamina_;
-            staminaMax_ = other.staminaMax_;
-            move1_ = other.move1_;
-            move2_ = other.move2_;
-            deployedFortId_ = other.deployedFortId_;
-            ownerName_ = other.ownerName_;
-            isEgg_ = other.isEgg_;
-            eggKmWalkedTarget_ = other.eggKmWalkedTarget_;
-            eggKmWalkedStart_ = other.eggKmWalkedStart_;
-            origin_ = other.origin_;
-            heightM_ = other.heightM_;
-            weightKg_ = other.weightKg_;
-            individualAttack_ = other.individualAttack_;
-            individualDefense_ = other.individualDefense_;
-            individualStamina_ = other.individualStamina_;
-            cpMultiplier_ = other.cpMultiplier_;
-            pokeball_ = other.pokeball_;
-            capturedCellId_ = other.capturedCellId_;
-            battlesAttacked_ = other.battlesAttacked_;
-            battlesDefended_ = other.battlesDefended_;
-            eggIncubatorId_ = other.eggIncubatorId_;
-            creationTimeMs_ = other.creationTimeMs_;
-            numUpgrades_ = other.numUpgrades_;
-            additionalCpMultiplier_ = other.additionalCpMultiplier_;
-            favorite_ = other.favorite_;
-            nickname_ = other.nickname_;
-            fromFort_ = other.fromFort_;
-        }
-
-        public double CalculateIV()
-        {
-            return ((double)(IndividualAttack + IndividualDefense + IndividualStamina) / (3.0f * 15.0f)) * 100.0f;
-        }
-
-        public static pb::MessageParser<PokemonData> Parser
-        {
-            get { return _parser; }
-        }
-
-        public static pbr::MessageDescriptor Descriptor
-        {
-            get { return global::PokemonGo.RocketAPI.GeneratedCode.PayloadsReflection.Descriptor.MessageTypes[32]; }
-        }
-
-        public ulong Id
-        {
-            get { return id_; }
-            set { id_ = value; }
-        }
-
-        public global::PokemonGo.RocketAPI.GeneratedCode.PokemonId PokemonId
-        {
-            get { return pokemonId_; }
-            set { pokemonId_ = value; }
-        }
-
-        public int Cp
-        {
-            get { return cp_; }
-            set { cp_ = value; }
-        }
-
-        public int Stamina
-        {
-            get { return stamina_; }
-            set { stamina_ = value; }
-        }
-
-        public int StaminaMax
-        {
-            get { return staminaMax_; }
-            set { staminaMax_ = value; }
-        }
-
-        public global::PokemonGo.RocketAPI.GeneratedCode.PokemonMove Move1
-        {
-            get { return move1_; }
-            set { move1_ = value; }
-        }
-
-        public global::PokemonGo.RocketAPI.GeneratedCode.PokemonMove Move2
-        {
-            get { return move2_; }
-            set { move2_ = value; }
-        }
-
-        public int DeployedFortId
-        {
-            get { return deployedFortId_; }
-            set { deployedFortId_ = value; }
-        }
-
-        public string OwnerName
-        {
-            get { return ownerName_; }
-            set { ownerName_ = pb::ProtoPreconditions.CheckNotNull(value, "value"); }
-        }
-
-        public bool IsEgg
-        {
-            get { return isEgg_; }
-            set { isEgg_ = value; }
-        }
-
-        public int EggKmWalkedTarget
-        {
-            get { return eggKmWalkedTarget_; }
-            set { eggKmWalkedTarget_ = value; }
-        }
-
-        public int EggKmWalkedStart
-        {
-            get { return eggKmWalkedStart_; }
-            set { eggKmWalkedStart_ = value; }
-        }
-
-        public int Origin
-        {
-            get { return origin_; }
-            set { origin_ = value; }
-        }
-
-        public float HeightM
-        {
-            get { return heightM_; }
-            set { heightM_ = value; }
-        }
-
-        public float WeightKg
-        {
-            get { return weightKg_; }
-            set { weightKg_ = value; }
-        }
-
-        public int IndividualAttack
-        {
-            get { return individualAttack_; }
-            set { individualAttack_ = value; }
-        }
-
-        public int IndividualDefense
-        {
-            get { return individualDefense_; }
-            set { individualDefense_ = value; }
-        }
-
-        public int IndividualStamina
-        {
-            get { return individualStamina_; }
-            set { individualStamina_ = value; }
-        }
-
-        public float CpMultiplier
-        {
-            get { return cpMultiplier_; }
-            set { cpMultiplier_ = value; }
-        }
-
-        public int Pokeball
-        {
-            get { return pokeball_; }
-            set { pokeball_ = value; }
-        }
-
-        public ulong CapturedCellId
-        {
-            get { return capturedCellId_; }
-            set { capturedCellId_ = value; }
-        }
-
-        public int BattlesAttacked
-        {
-            get { return battlesAttacked_; }
-            set { battlesAttacked_ = value; }
-        }
-
-        public int BattlesDefended
-        {
-            get { return battlesDefended_; }
-            set { battlesDefended_ = value; }
-        }
-
-        public int EggIncubatorId
-        {
-            get { return eggIncubatorId_; }
-            set { eggIncubatorId_ = value; }
-        }
-
-        public ulong CreationTimeMs
-        {
-            get { return creationTimeMs_; }
-            set { creationTimeMs_ = value; }
-        }
-
-        public int NumUpgrades
-        {
-            get { return numUpgrades_; }
-            set { numUpgrades_ = value; }
-        }
-
-        public float AdditionalCpMultiplier
-        {
-            get { return additionalCpMultiplier_; }
-            set { additionalCpMultiplier_ = value; }
-        }
-
-        public int Favorite
-        {
-            get { return favorite_; }
-            set { favorite_ = value; }
-        }
-
-        public string Nickname
-        {
-            get { return nickname_; }
-            set { nickname_ = pb::ProtoPreconditions.CheckNotNull(value, "value"); }
-        }
-
-        public int FromFort
-        {
-            get { return fromFort_; }
-            set { fromFort_ = value; }
-        }
-
-        pbr::MessageDescriptor pb::IMessage.Descriptor
-        {
-            get { return Descriptor; }
-        }
-
-        public PokemonData Clone()
-        {
-            return new PokemonData(this);
-        }
-
-        public bool Equals(PokemonData other)
-        {
-            if (ReferenceEquals(other, null))
-            {
-                return false;
-            }
-            if (ReferenceEquals(other, this))
-            {
-                return true;
-            }
-            if (Id != other.Id) return false;
-            if (PokemonId != other.PokemonId) return false;
-            if (Cp != other.Cp) return false;
-            if (Stamina != other.Stamina) return false;
-            if (StaminaMax != other.StaminaMax) return false;
-            if (Move1 != other.Move1) return false;
-            if (Move2 != other.Move2) return false;
-            if (DeployedFortId != other.DeployedFortId) return false;
-            if (OwnerName != other.OwnerName) return false;
-            if (IsEgg != other.IsEgg) return false;
-            if (EggKmWalkedTarget != other.EggKmWalkedTarget) return false;
-            if (EggKmWalkedStart != other.EggKmWalkedStart) return false;
-            if (Origin != other.Origin) return false;
-            if (HeightM != other.HeightM) return false;
-            if (WeightKg != other.WeightKg) return false;
-            if (IndividualAttack != other.IndividualAttack) return false;
-            if (IndividualDefense != other.IndividualDefense) return false;
-            if (IndividualStamina != other.IndividualStamina) return false;
-            if (CpMultiplier != other.CpMultiplier) return false;
-            if (Pokeball != other.Pokeball) return false;
-            if (CapturedCellId != other.CapturedCellId) return false;
-            if (BattlesAttacked != other.BattlesAttacked) return false;
-            if (BattlesDefended != other.BattlesDefended) return false;
-            if (EggIncubatorId != other.EggIncubatorId) return false;
-            if (CreationTimeMs != other.CreationTimeMs) return false;
-            if (NumUpgrades != other.NumUpgrades) return false;
-            if (AdditionalCpMultiplier != other.AdditionalCpMultiplier) return false;
-            if (Favorite != other.Favorite) return false;
-            if (Nickname != other.Nickname) return false;
-            if (FromFort != other.FromFort) return false;
-            return true;
-        }
-
-        public void WriteTo(pb::CodedOutputStream output)
-        {
-            if (Id != 0UL)
-            {
-                output.WriteRawTag(9);
-                output.WriteFixed64(Id);
-            }
-            if (PokemonId != 0)
-            {
-                output.WriteRawTag(16);
-                output.WriteEnum((int)PokemonId);
-            }
-            if (Cp != 0)
-            {
-                output.WriteRawTag(24);
-                output.WriteInt32(Cp);
-            }
-            if (Stamina != 0)
-            {
-                output.WriteRawTag(32);
-                output.WriteInt32(Stamina);
-            }
-            if (StaminaMax != 0)
-            {
-                output.WriteRawTag(40);
-                output.WriteInt32(StaminaMax);
-            }
-            if (Move1 != 0)
-            {
-                output.WriteRawTag(48);
-                output.WriteEnum((int)Move1);
-            }
-            if (Move2 != 0)
-            {
-                output.WriteRawTag(56);
-                output.WriteEnum((int)Move2);
-            }
-            if (DeployedFortId != 0)
-            {
-                output.WriteRawTag(64);
-                output.WriteInt32(DeployedFortId);
-            }
-            if (OwnerName.Length != 0)
-            {
-                output.WriteRawTag(74);
-                output.WriteString(OwnerName);
-            }
-            if (IsEgg != false)
-            {
-                output.WriteRawTag(80);
-                output.WriteBool(IsEgg);
-            }
-            if (EggKmWalkedTarget != 0)
-            {
-                output.WriteRawTag(88);
-                output.WriteInt32(EggKmWalkedTarget);
-            }
-            if (EggKmWalkedStart != 0)
-            {
-                output.WriteRawTag(96);
-                output.WriteInt32(EggKmWalkedStart);
-            }
-            if (Origin != 0)
-            {
-                output.WriteRawTag(112);
-                output.WriteInt32(Origin);
-            }
-            if (HeightM != 0F)
-            {
-                output.WriteRawTag(125);
-                output.WriteFloat(HeightM);
-            }
-            if (WeightKg != 0F)
-            {
-                output.WriteRawTag(133, 1);
-                output.WriteFloat(WeightKg);
-            }
-            if (IndividualAttack != 0)
-            {
-                output.WriteRawTag(136, 1);
-                output.WriteInt32(IndividualAttack);
-            }
-            if (IndividualDefense != 0)
-            {
-                output.WriteRawTag(144, 1);
-                output.WriteInt32(IndividualDefense);
-            }
-            if (IndividualStamina != 0)
-            {
-                output.WriteRawTag(152, 1);
-                output.WriteInt32(IndividualStamina);
-            }
-            if (CpMultiplier != 0)
-            {
-                output.WriteRawTag(165, 1);
-                output.WriteFloat(CpMultiplier);
-            }
-            if (Pokeball != 0)
-            {
-                output.WriteRawTag(168, 1);
-                output.WriteInt32(Pokeball);
-            }
-            if (CapturedCellId != 0UL)
-            {
-                output.WriteRawTag(176, 1);
-                output.WriteUInt64(CapturedCellId);
-            }
-            if (BattlesAttacked != 0)
-            {
-                output.WriteRawTag(184, 1);
-                output.WriteInt32(BattlesAttacked);
-            }
-            if (BattlesDefended != 0)
-            {
-                output.WriteRawTag(192, 1);
-                output.WriteInt32(BattlesDefended);
-            }
-            if (EggIncubatorId != 0)
-            {
-                output.WriteRawTag(200, 1);
-                output.WriteInt32(EggIncubatorId);
-            }
-            if (CreationTimeMs != 0UL)
-            {
-                output.WriteRawTag(208, 1);
-                output.WriteUInt64(CreationTimeMs);
-            }
-            if (NumUpgrades != 0)
-            {
-                output.WriteRawTag(216, 1);
-                output.WriteInt32(NumUpgrades);
-            }
-            if (AdditionalCpMultiplier != 0)
-            {
-                output.WriteRawTag(229, 1);
-                output.WriteFloat(AdditionalCpMultiplier);
-            }
-            if (Favorite != 0)
-            {
-                output.WriteRawTag(232, 1);
-                output.WriteInt32(Favorite);
-            }
-            if (Nickname.Length != 0)
-            {
-                output.WriteRawTag(242, 1);
-                output.WriteString(Nickname);
-            }
-            if (FromFort != 0)
-            {
-                output.WriteRawTag(248, 1);
-                output.WriteInt32(FromFort);
-            }
-        }
-
-        public int CalculateSize()
-        {
-            var size = 0;
-            if (Id != 0UL)
-            {
-                size += 1 + 8;
-            }
-            if (PokemonId != 0)
-            {
-                size += 1 + pb::CodedOutputStream.ComputeEnumSize((int)PokemonId);
-            }
-            if (Cp != 0)
-            {
-                size += 1 + pb::CodedOutputStream.ComputeInt32Size(Cp);
-            }
-            if (Stamina != 0)
-            {
-                size += 1 + pb::CodedOutputStream.ComputeInt32Size(Stamina);
-            }
-            if (StaminaMax != 0)
-            {
-                size += 1 + pb::CodedOutputStream.ComputeInt32Size(StaminaMax);
-            }
-            if (Move1 != 0)
-            {
-                size += 1 + pb::CodedOutputStream.ComputeEnumSize((int)Move1);
-            }
-            if (Move2 != 0)
-            {
-                size += 1 + pb::CodedOutputStream.ComputeEnumSize((int)Move2);
-            }
-            if (DeployedFortId != 0)
-            {
-                size += 1 + pb::CodedOutputStream.ComputeInt32Size(DeployedFortId);
-            }
-            if (OwnerName.Length != 0)
-            {
-                size += 1 + pb::CodedOutputStream.ComputeStringSize(OwnerName);
-            }
-            if (IsEgg != false)
-            {
-                size += 1 + 1;
-            }
-            if (EggKmWalkedTarget != 0)
-            {
-                size += 1 + pb::CodedOutputStream.ComputeInt32Size(EggKmWalkedTarget);
-            }
-            if (EggKmWalkedStart != 0)
-            {
-                size += 1 + pb::CodedOutputStream.ComputeInt32Size(EggKmWalkedStart);
-            }
-            if (Origin != 0)
-            {
-                size += 1 + pb::CodedOutputStream.ComputeInt32Size(Origin);
-            }
-            if (HeightM != 0F)
-            {
-                size += 1 + 4;
-            }
-            if (WeightKg != 0F)
-            {
-                size += 2 + 4;
-            }
-            if (IndividualAttack != 0)
-            {
-                size += 2 + pb::CodedOutputStream.ComputeInt32Size(IndividualAttack);
-            }
-            if (IndividualDefense != 0)
-            {
-                size += 2 + pb::CodedOutputStream.ComputeInt32Size(IndividualDefense);
-            }
-            if (IndividualStamina != 0)
-            {
-                size += 2 + pb::CodedOutputStream.ComputeInt32Size(IndividualStamina);
-            }
-            if (CpMultiplier != 0F)
-            {
-                size += 2 + 4;
-            }
-            if (Pokeball != 0)
-            {
-                size += 2 + pb::CodedOutputStream.ComputeInt32Size(Pokeball);
-            }
-            if (CapturedCellId != 0UL)
-            {
-                size += 2 + pb::CodedOutputStream.ComputeUInt64Size(CapturedCellId);
-            }
-            if (BattlesAttacked != 0)
-            {
-                size += 2 + pb::CodedOutputStream.ComputeInt32Size(BattlesAttacked);
-            }
-            if (BattlesDefended != 0)
-            {
-                size += 2 + pb::CodedOutputStream.ComputeInt32Size(BattlesDefended);
-            }
-            if (EggIncubatorId != 0)
-            {
-                size += 2 + pb::CodedOutputStream.ComputeInt32Size(EggIncubatorId);
-            }
-            if (CreationTimeMs != 0UL)
-            {
-                size += 2 + pb::CodedOutputStream.ComputeUInt64Size(CreationTimeMs);
-            }
-            if (NumUpgrades != 0)
-            {
-                size += 2 + pb::CodedOutputStream.ComputeInt32Size(NumUpgrades);
-            }
-            if (AdditionalCpMultiplier != 0F)
-            {
-                size += 2 + 4;
-            }
-            if (Favorite != 0)
-            {
-                size += 2 + pb::CodedOutputStream.ComputeInt32Size(Favorite);
-            }
-            if (Nickname.Length != 0)
-            {
-                size += 2 + pb::CodedOutputStream.ComputeStringSize(Nickname);
-            }
-            if (FromFort != 0)
-            {
-                size += 2 + pb::CodedOutputStream.ComputeInt32Size(FromFort);
-            }
-            return size;
-        }
-
-        public void MergeFrom(PokemonData other)
-        {
-            if (other == null)
-            {
-                return;
-            }
-            if (other.Id != 0UL)
-            {
-                Id = other.Id;
-            }
-            if (other.PokemonId != 0)
-            {
-                PokemonId = other.PokemonId;
-            }
-            if (other.Cp != 0)
-            {
-                Cp = other.Cp;
-            }
-            if (other.Stamina != 0)
-            {
-                Stamina = other.Stamina;
-            }
-            if (other.StaminaMax != 0)
-            {
-                StaminaMax = other.StaminaMax;
-            }
-            if (other.Move1 != 0)
-            {
-                Move1 = other.Move1;
-            }
-            if (other.Move2 != 0)
-            {
-                Move2 = other.Move2;
-            }
-            if (other.DeployedFortId != 0)
-            {
-                DeployedFortId = other.DeployedFortId;
-            }
-            if (other.OwnerName.Length != 0)
-            {
-                OwnerName = other.OwnerName;
-            }
-            if (other.IsEgg != false)
-            {
-                IsEgg = other.IsEgg;
-            }
-            if (other.EggKmWalkedTarget != 0)
-            {
-                EggKmWalkedTarget = other.EggKmWalkedTarget;
-            }
-            if (other.EggKmWalkedStart != 0)
-            {
-                EggKmWalkedStart = other.EggKmWalkedStart;
-            }
-            if (other.Origin != 0)
-            {
-                Origin = other.Origin;
-            }
-            if (other.HeightM != 0F)
-            {
-                HeightM = other.HeightM;
-            }
-            if (other.WeightKg != 0F)
-            {
-                WeightKg = other.WeightKg;
-            }
-            if (other.IndividualAttack != 0)
-            {
-                IndividualAttack = other.IndividualAttack;
-            }
-            if (other.IndividualDefense != 0)
-            {
-                IndividualDefense = other.IndividualDefense;
-            }
-            if (other.IndividualStamina != 0)
-            {
-                IndividualStamina = other.IndividualStamina;
-            }
-            if (other.CpMultiplier != 0F)
-            {
-                CpMultiplier = other.CpMultiplier;
-            }
-            if (other.Pokeball != 0)
-            {
-                Pokeball = other.Pokeball;
-            }
-            if (other.CapturedCellId != 0UL)
-            {
-                CapturedCellId = other.CapturedCellId;
-            }
-            if (other.BattlesAttacked != 0)
-            {
-                BattlesAttacked = other.BattlesAttacked;
-            }
-            if (other.BattlesDefended != 0)
-            {
-                BattlesDefended = other.BattlesDefended;
-            }
-            if (other.EggIncubatorId != 0)
-            {
-                EggIncubatorId = other.EggIncubatorId;
-            }
-            if (other.CreationTimeMs != 0UL)
-            {
-                CreationTimeMs = other.CreationTimeMs;
-            }
-            if (other.NumUpgrades != 0)
-            {
-                NumUpgrades = other.NumUpgrades;
-            }
-            if (other.AdditionalCpMultiplier != 0F)
-            {
-                AdditionalCpMultiplier = other.AdditionalCpMultiplier;
-            }
-            if (other.Favorite != 0)
-            {
-                Favorite = other.Favorite;
-            }
-            if (other.Nickname.Length != 0)
-            {
-                Nickname = other.Nickname;
-            }
-            if (other.FromFort != 0)
-            {
-                FromFort = other.FromFort;
-            }
-        }
-
-        public void MergeFrom(pb::CodedInputStream input)
-        {
-            uint tag;
-            while ((tag = input.ReadTag()) != 0)
-            {
-                switch (tag)
-                {
-                    default:
-                        input.SkipLastField();
-                        break;
-                    case 9:
-                        {
-                            Id = input.ReadFixed64();
-                            break;
-                        }
-                    case 16:
-                        {
-                            pokemonId_ = (global::PokemonGo.RocketAPI.GeneratedCode.PokemonId)input.ReadEnum();
-                            break;
-                        }
-                    case 24:
-                        {
-                            Cp = input.ReadInt32();
-                            break;
-                        }
-                    case 32:
-                        {
-                            Stamina = input.ReadInt32();
-                            break;
-                        }
-                    case 40:
-                        {
-                            StaminaMax = input.ReadInt32();
-                            break;
-                        }
-                    case 48:
-                        {
-                            move1_ = (global::PokemonGo.RocketAPI.GeneratedCode.PokemonMove)input.ReadEnum();
-                            break;
-                        }
-                    case 56:
-                        {
-                            move2_ = (global::PokemonGo.RocketAPI.GeneratedCode.PokemonMove)input.ReadEnum();
-                            break;
-                        }
-                    case 64:
-                        {
-                            DeployedFortId = input.ReadInt32();
-                            break;
-                        }
-                    case 74:
-                        {
-                            OwnerName = input.ReadString();
-                            break;
-                        }
-                    case 80:
-                        {
-                            IsEgg = input.ReadBool();
-                            break;
-                        }
-                    case 88:
-                        {
-                            EggKmWalkedTarget = input.ReadInt32();
-                            break;
-                        }
-                    case 96:
-                        {
-                            EggKmWalkedStart = input.ReadInt32();
-                            break;
-                        }
-                    case 112:
-                        {
-                            Origin = input.ReadInt32();
-                            break;
-                        }
-                    case 125:
-                        {
-                            HeightM = input.ReadFloat();
-                            break;
-                        }
-                    case 133:
-                        {
-                            WeightKg = input.ReadFloat();
-                            break;
-                        }
-                    case 136:
-                        {
-                            IndividualAttack = input.ReadInt32();
-                            break;
-                        }
-                    case 144:
-                        {
-                            IndividualDefense = input.ReadInt32();
-                            break;
-                        }
-                    case 152:
-                        {
-                            IndividualStamina = input.ReadInt32();
-                            break;
-                        }
-                    case 165:
-                        {
-                            CpMultiplier = input.ReadFloat();
-                            break;
-                        }
-                    case 168:
-                        {
-                            Pokeball = input.ReadInt32();
-                            break;
-                        }
-                    case 176:
-                        {
-                            CapturedCellId = input.ReadUInt64();
-                            break;
-                        }
-                    case 184:
-                        {
-                            BattlesAttacked = input.ReadInt32();
-                            break;
-                        }
-                    case 192:
-                        {
-                            BattlesDefended = input.ReadInt32();
-                            break;
-                        }
-                    case 200:
-                        {
-                            EggIncubatorId = input.ReadInt32();
-                            break;
-                        }
-                    case 208:
-                        {
-                            CreationTimeMs = input.ReadUInt64();
-                            break;
-                        }
-                    case 216:
-                        {
-                            NumUpgrades = input.ReadInt32();
-                            break;
-                        }
-                    case 229:
-                        {
-                            AdditionalCpMultiplier = input.ReadFloat();
-                            break;
-                        }
-                    case 232:
-                        {
-                            Favorite = input.ReadInt32();
-                            break;
-                        }
-                    case 242:
-                        {
-                            Nickname = input.ReadString();
-                            break;
-                        }
-                    case 248:
-                        {
-                            FromFort = input.ReadInt32();
-                            break;
-                        }
-                }
-            }
-        }
-
-        public override bool Equals(object other)
-        {
-            return Equals(other as PokemonData);
-        }
-
-        public override int GetHashCode()
-        {
-            var hash = 1;
-            if (Id != 0UL) hash ^= Id.GetHashCode();
-            if (PokemonId != 0) hash ^= PokemonId.GetHashCode();
-            if (Cp != 0) hash ^= Cp.GetHashCode();
-            if (Stamina != 0) hash ^= Stamina.GetHashCode();
-            if (StaminaMax != 0) hash ^= StaminaMax.GetHashCode();
-            if (Move1 != 0) hash ^= Move1.GetHashCode();
-            if (Move2 != 0) hash ^= Move2.GetHashCode();
-            if (DeployedFortId != 0) hash ^= DeployedFortId.GetHashCode();
-            if (OwnerName.Length != 0) hash ^= OwnerName.GetHashCode();
-            if (IsEgg != false) hash ^= IsEgg.GetHashCode();
-            if (EggKmWalkedTarget != 0) hash ^= EggKmWalkedTarget.GetHashCode();
-            if (EggKmWalkedStart != 0) hash ^= EggKmWalkedStart.GetHashCode();
-            if (Origin != 0) hash ^= Origin.GetHashCode();
-            if (HeightM != 0F) hash ^= HeightM.GetHashCode();
-            if (WeightKg != 0F) hash ^= WeightKg.GetHashCode();
-            if (IndividualAttack != 0) hash ^= IndividualAttack.GetHashCode();
-            if (IndividualDefense != 0) hash ^= IndividualDefense.GetHashCode();
-            if (IndividualStamina != 0) hash ^= IndividualStamina.GetHashCode();
-            if (CpMultiplier != 0) hash ^= CpMultiplier.GetHashCode();
-            if (Pokeball != 0) hash ^= Pokeball.GetHashCode();
-            if (CapturedCellId != 0UL) hash ^= CapturedCellId.GetHashCode();
-            if (BattlesAttacked != 0) hash ^= BattlesAttacked.GetHashCode();
-            if (BattlesDefended != 0) hash ^= BattlesDefended.GetHashCode();
-            if (EggIncubatorId != 0) hash ^= EggIncubatorId.GetHashCode();
-            if (CreationTimeMs != 0UL) hash ^= CreationTimeMs.GetHashCode();
-            if (NumUpgrades != 0) hash ^= NumUpgrades.GetHashCode();
-            if (AdditionalCpMultiplier != 0) hash ^= AdditionalCpMultiplier.GetHashCode();
-            if (Favorite != 0) hash ^= Favorite.GetHashCode();
-            if (Nickname.Length != 0) hash ^= Nickname.GetHashCode();
-            if (FromFort != 0) hash ^= FromFort.GetHashCode();
-            return hash;
-        }
-
-        partial void OnConstruction();
-
-        public override string ToString()
-        {
-            return pb::JsonFormatter.ToDiagnosticString(this);
-        }
-    }
-
-    [global::System.Diagnostics.DebuggerNonUserCodeAttribute()]
-    public sealed partial class MapPokemon : pb::IMessage<MapPokemon>
-    {
-        /// <summary>Field number for the "spawnpoint_id" field.</summary>
-        public const int SpawnpointIdFieldNumber = 1;
-
-        /// <summary>Field number for the "encounter_id" field.</summary>
-        public const int EncounterIdFieldNumber = 2;
-
-        /// <summary>Field number for the "pokemon_id" field.</summary>
-        public const int PokemonIdFieldNumber = 3;
-
-        /// <summary>Field number for the "expiration_timestamp_ms" field.</summary>
-        public const int ExpirationTimestampMsFieldNumber = 4;
-
-        /// <summary>Field number for the "latitude" field.</summary>
-        public const int LatitudeFieldNumber = 5;
-
-        /// <summary>Field number for the "longitude" field.</summary>
-        public const int LongitudeFieldNumber = 6;
-
-        private static readonly pb::MessageParser<MapPokemon> _parser =
-            new pb::MessageParser<MapPokemon>(() => new MapPokemon());
-
-        private ulong encounterId_;
-        private long expirationTimestampMs_;
-        private double latitude_;
-        private double longitude_;
-        private global::PokemonGo.RocketAPI.GeneratedCode.PokemonId pokemonId_ = 0;
-        private string spawnpointId_ = "";
-
-        public MapPokemon()
-        {
-            OnConstruction();
-        }
-
-        public MapPokemon(MapPokemon other) : this()
-        {
-            spawnpointId_ = other.spawnpointId_;
-            encounterId_ = other.encounterId_;
-            pokemonId_ = other.pokemonId_;
-            expirationTimestampMs_ = other.expirationTimestampMs_;
-            latitude_ = other.latitude_;
-            longitude_ = other.longitude_;
-        }
-
-        public static pb::MessageParser<MapPokemon> Parser
-        {
-            get { return _parser; }
-        }
-
-        public static pbr::MessageDescriptor Descriptor
-        {
-            get { return global::PokemonGo.RocketAPI.GeneratedCode.PayloadsReflection.Descriptor.MessageTypes[33]; }
-        }
-
-        public string SpawnpointId
-        {
-            get { return spawnpointId_; }
-            set { spawnpointId_ = pb::ProtoPreconditions.CheckNotNull(value, "value"); }
-        }
-
-        public ulong EncounterId
-        {
-            get { return encounterId_; }
-            set { encounterId_ = value; }
-        }
-
-        public global::PokemonGo.RocketAPI.GeneratedCode.PokemonId PokemonId
-        {
-            get { return pokemonId_; }
-            set { pokemonId_ = value; }
-        }
-
-        /// <summary>
-        ///     After this timestamp, the pokemon will be gone.
-        /// </summary>
-        public long ExpirationTimestampMs
-        {
-            get { return expirationTimestampMs_; }
-            set { expirationTimestampMs_ = value; }
-        }
-
-        public double Latitude
-        {
-            get { return latitude_; }
-            set { latitude_ = value; }
-        }
-
-        public double Longitude
-        {
-            get { return longitude_; }
-            set { longitude_ = value; }
-        }
-
-        pbr::MessageDescriptor pb::IMessage.Descriptor
-        {
-            get { return Descriptor; }
-        }
-
-        public MapPokemon Clone()
-        {
-            return new MapPokemon(this);
-        }
-
-        public bool Equals(MapPokemon other)
-        {
-            if (ReferenceEquals(other, null))
-            {
-                return false;
-            }
-            if (ReferenceEquals(other, this))
-            {
-                return true;
-            }
-            if (SpawnpointId != other.SpawnpointId) return false;
-            if (EncounterId != other.EncounterId) return false;
-            if (PokemonId != other.PokemonId) return false;
-            if (ExpirationTimestampMs != other.ExpirationTimestampMs) return false;
-            if (Latitude != other.Latitude) return false;
-            if (Longitude != other.Longitude) return false;
-            return true;
-        }
-
-        public void WriteTo(pb::CodedOutputStream output)
-        {
-            if (SpawnpointId.Length != 0)
-            {
-                output.WriteRawTag(10);
-                output.WriteString(SpawnpointId);
-            }
-            if (EncounterId != 0UL)
-            {
-                output.WriteRawTag(17);
-                output.WriteFixed64(EncounterId);
-            }
-            if (PokemonId != 0)
-            {
-                output.WriteRawTag(24);
-                output.WriteEnum((int)PokemonId);
-            }
-            if (ExpirationTimestampMs != 0L)
-            {
-                output.WriteRawTag(32);
-                output.WriteInt64(ExpirationTimestampMs);
-            }
-            if (Latitude != 0D)
-            {
-                output.WriteRawTag(41);
-                output.WriteDouble(Latitude);
-            }
-            if (Longitude != 0D)
-            {
-                output.WriteRawTag(49);
-                output.WriteDouble(Longitude);
-            }
-        }
-
-        public int CalculateSize()
-        {
-            var size = 0;
-            if (SpawnpointId.Length != 0)
-            {
-                size += 1 + pb::CodedOutputStream.ComputeStringSize(SpawnpointId);
-            }
-            if (EncounterId != 0UL)
-            {
-                size += 1 + 8;
-            }
-            if (PokemonId != 0)
-            {
-                size += 1 + pb::CodedOutputStream.ComputeEnumSize((int)PokemonId);
-            }
-            if (ExpirationTimestampMs != 0L)
-            {
-                size += 1 + pb::CodedOutputStream.ComputeInt64Size(ExpirationTimestampMs);
-            }
-            if (Latitude != 0D)
-            {
-                size += 1 + 8;
-            }
-            if (Longitude != 0D)
-            {
-                size += 1 + 8;
-            }
-            return size;
-        }
-
-        public void MergeFrom(MapPokemon other)
-        {
-            if (other == null)
-            {
-                return;
-            }
-            if (other.SpawnpointId.Length != 0)
-            {
-                SpawnpointId = other.SpawnpointId;
-            }
-            if (other.EncounterId != 0UL)
-            {
-                EncounterId = other.EncounterId;
-            }
-            if (other.PokemonId != 0)
-            {
-                PokemonId = other.PokemonId;
-            }
-            if (other.ExpirationTimestampMs != 0L)
-            {
-                ExpirationTimestampMs = other.ExpirationTimestampMs;
-            }
-            if (other.Latitude != 0D)
-            {
-                Latitude = other.Latitude;
-            }
-            if (other.Longitude != 0D)
-            {
-                Longitude = other.Longitude;
-            }
-        }
-
-        public void MergeFrom(pb::CodedInputStream input)
-        {
-            uint tag;
-            while ((tag = input.ReadTag()) != 0)
-            {
-                switch (tag)
-                {
-                    default:
-                        input.SkipLastField();
-                        break;
-                    case 10:
-                        {
-                            SpawnpointId = input.ReadString();
-                            break;
-                        }
-                    case 17:
-                        {
-                            EncounterId = input.ReadFixed64();
-                            break;
-                        }
-                    case 24:
-                        {
-                            pokemonId_ = (global::PokemonGo.RocketAPI.GeneratedCode.PokemonId)input.ReadEnum();
-                            break;
-                        }
-                    case 32:
-                        {
-                            ExpirationTimestampMs = input.ReadInt64();
-                            break;
-                        }
-                    case 41:
-                        {
-                            Latitude = input.ReadDouble();
-                            break;
-                        }
-                    case 49:
-                        {
-                            Longitude = input.ReadDouble();
-                            break;
-                        }
-                }
-            }
-        }
-
-        public override bool Equals(object other)
-        {
-            return Equals(other as MapPokemon);
-        }
-
-        public override int GetHashCode()
-        {
-            var hash = 1;
-            if (SpawnpointId.Length != 0) hash ^= SpawnpointId.GetHashCode();
-            if (EncounterId != 0UL) hash ^= EncounterId.GetHashCode();
-            if (PokemonId != 0) hash ^= PokemonId.GetHashCode();
-            if (ExpirationTimestampMs != 0L) hash ^= ExpirationTimestampMs.GetHashCode();
-            if (Latitude != 0D) hash ^= Latitude.GetHashCode();
-            if (Longitude != 0D) hash ^= Longitude.GetHashCode();
-            return hash;
-        }
-
-        partial void OnConstruction();
-
-        public override string ToString()
-        {
-            return pb::JsonFormatter.ToDiagnosticString(this);
-        }
-    }
-
-    [global::System.Diagnostics.DebuggerNonUserCodeAttribute()]
-    public sealed partial class NearbyPokemon : pb::IMessage<NearbyPokemon>
-    {
-        /// <summary>Field number for the "pokemon_id" field.</summary>
-        public const int PokemonIdFieldNumber = 1;
-
-        /// <summary>Field number for the "distance_in_meters" field.</summary>
-        public const int DistanceInMetersFieldNumber = 2;
-
-        /// <summary>Field number for the "encounter_id" field.</summary>
-        public const int EncounterIdFieldNumber = 3;
-
-        private static readonly pb::MessageParser<NearbyPokemon> _parser =
-            new pb::MessageParser<NearbyPokemon>(() => new NearbyPokemon());
-
-        private float distanceInMeters_;
-        private ulong encounterId_;
-        private global::PokemonGo.RocketAPI.GeneratedCode.PokemonId pokemonId_ = 0;
-
-        public NearbyPokemon()
-        {
-            OnConstruction();
-        }
-
-        public NearbyPokemon(NearbyPokemon other) : this()
-        {
-            pokemonId_ = other.pokemonId_;
-            distanceInMeters_ = other.distanceInMeters_;
-            encounterId_ = other.encounterId_;
-        }
-
-        public static pb::MessageParser<NearbyPokemon> Parser
-        {
-            get { return _parser; }
-        }
-
-        public static pbr::MessageDescriptor Descriptor
-        {
-            get { return global::PokemonGo.RocketAPI.GeneratedCode.PayloadsReflection.Descriptor.MessageTypes[34]; }
-        }
-
-        public global::PokemonGo.RocketAPI.GeneratedCode.PokemonId PokemonId
-        {
-            get { return pokemonId_; }
-            set { pokemonId_ = value; }
-        }
-
-        public float DistanceInMeters
-        {
-            get { return distanceInMeters_; }
-            set { distanceInMeters_ = value; }
-        }
-
-        public ulong EncounterId
-        {
-            get { return encounterId_; }
-            set { encounterId_ = value; }
-        }
-
-        pbr::MessageDescriptor pb::IMessage.Descriptor
-        {
-            get { return Descriptor; }
-        }
-
-        public NearbyPokemon Clone()
-        {
-            return new NearbyPokemon(this);
-        }
-
-        public bool Equals(NearbyPokemon other)
-        {
-            if (ReferenceEquals(other, null))
-            {
-                return false;
-            }
-            if (ReferenceEquals(other, this))
-            {
-                return true;
-            }
-            if (PokemonId != other.PokemonId) return false;
-            if (DistanceInMeters != other.DistanceInMeters) return false;
-            if (EncounterId != other.EncounterId) return false;
-            return true;
-        }
-
-        public void WriteTo(pb::CodedOutputStream output)
-        {
-            if (PokemonId != 0)
-            {
-                output.WriteRawTag(8);
-                output.WriteEnum((int)PokemonId);
-            }
-            if (DistanceInMeters != 0F)
-            {
-                output.WriteRawTag(21);
-                output.WriteFloat(DistanceInMeters);
-            }
-            if (EncounterId != 0UL)
-            {
-                output.WriteRawTag(25);
-                output.WriteFixed64(EncounterId);
-            }
-        }
-
-        public int CalculateSize()
-        {
-            var size = 0;
-            if (PokemonId != 0)
-            {
-                size += 1 + pb::CodedOutputStream.ComputeEnumSize((int)PokemonId);
-            }
-            if (DistanceInMeters != 0F)
-            {
-                size += 1 + 4;
-            }
-            if (EncounterId != 0UL)
-            {
-                size += 1 + 8;
-            }
-            return size;
-        }
-
-        public void MergeFrom(NearbyPokemon other)
-        {
-            if (other == null)
-            {
-                return;
-            }
-            if (other.PokemonId != 0)
-            {
-                PokemonId = other.PokemonId;
-            }
-            if (other.DistanceInMeters != 0F)
-            {
-                DistanceInMeters = other.DistanceInMeters;
-            }
-            if (other.EncounterId != 0UL)
-            {
-                EncounterId = other.EncounterId;
-            }
-        }
-
-        public void MergeFrom(pb::CodedInputStream input)
-        {
-            uint tag;
-            while ((tag = input.ReadTag()) != 0)
-            {
-                switch (tag)
-                {
-                    default:
-                        input.SkipLastField();
-                        break;
-                    case 8:
-                        {
-                            pokemonId_ = (global::PokemonGo.RocketAPI.GeneratedCode.PokemonId)input.ReadEnum();
-                            break;
-                        }
-                    case 21:
-                        {
-                            DistanceInMeters = input.ReadFloat();
-                            break;
-                        }
-                    case 25:
-                        {
-                            EncounterId = input.ReadFixed64();
-                            break;
-                        }
-                }
-            }
-        }
-
-        public override bool Equals(object other)
-        {
-            return Equals(other as NearbyPokemon);
-        }
-
-        public override int GetHashCode()
-        {
-            var hash = 1;
-            if (PokemonId != 0) hash ^= PokemonId.GetHashCode();
-            if (DistanceInMeters != 0F) hash ^= DistanceInMeters.GetHashCode();
-            if (EncounterId != 0UL) hash ^= EncounterId.GetHashCode();
-            return hash;
-        }
-
-        partial void OnConstruction();
-
-        public override string ToString()
-        {
-            return pb::JsonFormatter.ToDiagnosticString(this);
-        }
-    }
-
-    [global::System.Diagnostics.DebuggerNonUserCodeAttribute()]
-    public sealed partial class DownloadSettingsResponse : pb::IMessage<DownloadSettingsResponse>
-    {
-        /// <summary>Field number for the "error" field.</summary>
-        public const int ErrorFieldNumber = 1;
-
-        /// <summary>Field number for the "hash" field.</summary>
-        public const int HashFieldNumber = 2;
-
-        /// <summary>Field number for the "settings" field.</summary>
-        public const int SettingsFieldNumber = 3;
-
-        private static readonly pb::MessageParser<DownloadSettingsResponse> _parser =
-            new pb::MessageParser<DownloadSettingsResponse>(() => new DownloadSettingsResponse());
-
-        private string error_ = "";
-        private string hash_ = "";
-        private global::PokemonGo.RocketAPI.GeneratedCode.GlobalSettings settings_;
-
-        public DownloadSettingsResponse()
-        {
-            OnConstruction();
-        }
-
-        public DownloadSettingsResponse(DownloadSettingsResponse other) : this()
-        {
-            error_ = other.error_;
-            hash_ = other.hash_;
-            Settings = other.settings_ != null ? other.Settings.Clone() : null;
-        }
-
-        public static pb::MessageParser<DownloadSettingsResponse> Parser
-        {
-            get { return _parser; }
-        }
-
-        public static pbr::MessageDescriptor Descriptor
-        {
-            get { return global::PokemonGo.RocketAPI.GeneratedCode.PayloadsReflection.Descriptor.MessageTypes[35]; }
-        }
-
-        public string Error
-        {
-            get { return error_; }
-            set { error_ = pb::ProtoPreconditions.CheckNotNull(value, "value"); }
-        }
-
-        public string Hash
-        {
-            get { return hash_; }
-            set { hash_ = pb::ProtoPreconditions.CheckNotNull(value, "value"); }
-        }
-
-        public global::PokemonGo.RocketAPI.GeneratedCode.GlobalSettings Settings
-        {
-            get { return settings_; }
-            set { settings_ = value; }
-        }
-
-        pbr::MessageDescriptor pb::IMessage.Descriptor
-        {
-            get { return Descriptor; }
-        }
-
-        public DownloadSettingsResponse Clone()
-        {
-            return new DownloadSettingsResponse(this);
-        }
-
-        public bool Equals(DownloadSettingsResponse other)
-        {
-            if (ReferenceEquals(other, null))
-            {
-                return false;
-            }
-            if (ReferenceEquals(other, this))
-            {
-                return true;
-            }
-            if (Error != other.Error) return false;
-            if (Hash != other.Hash) return false;
-            if (!Equals(Settings, other.Settings)) return false;
-            return true;
-        }
-
-        public void WriteTo(pb::CodedOutputStream output)
-        {
-            if (Error.Length != 0)
-            {
-                output.WriteRawTag(10);
-                output.WriteString(Error);
-            }
-            if (Hash.Length != 0)
-            {
-                output.WriteRawTag(18);
-                output.WriteString(Hash);
-            }
-            if (settings_ != null)
-            {
-                output.WriteRawTag(26);
-                output.WriteMessage(Settings);
-            }
-        }
-
-        public int CalculateSize()
-        {
-            var size = 0;
-            if (Error.Length != 0)
-            {
-                size += 1 + pb::CodedOutputStream.ComputeStringSize(Error);
-            }
-            if (Hash.Length != 0)
-            {
-                size += 1 + pb::CodedOutputStream.ComputeStringSize(Hash);
-            }
-            if (settings_ != null)
-            {
-                size += 1 + pb::CodedOutputStream.ComputeMessageSize(Settings);
-            }
-            return size;
-        }
-
-        public void MergeFrom(DownloadSettingsResponse other)
-        {
-            if (other == null)
-            {
-                return;
-            }
-            if (other.Error.Length != 0)
-            {
-                Error = other.Error;
-            }
-            if (other.Hash.Length != 0)
-            {
-                Hash = other.Hash;
-            }
-            if (other.settings_ != null)
-            {
-                if (settings_ == null)
-                {
-                    settings_ = new global::PokemonGo.RocketAPI.GeneratedCode.GlobalSettings();
-                }
-                Settings.MergeFrom(other.Settings);
-            }
-        }
-
-        public void MergeFrom(pb::CodedInputStream input)
-        {
-            uint tag;
-            while ((tag = input.ReadTag()) != 0)
-            {
-                switch (tag)
-                {
-                    default:
-                        input.SkipLastField();
-                        break;
-                    case 10:
-                        {
-                            Error = input.ReadString();
-                            break;
-                        }
-                    case 18:
-                        {
-                            Hash = input.ReadString();
-                            break;
-                        }
-                    case 26:
-                        {
-                            if (settings_ == null)
-                            {
-                                settings_ = new global::PokemonGo.RocketAPI.GeneratedCode.GlobalSettings();
-                            }
-                            input.ReadMessage(settings_);
-                            break;
-                        }
-                }
-            }
-        }
-
-        public override bool Equals(object other)
-        {
-            return Equals(other as DownloadSettingsResponse);
-        }
-
-        public override int GetHashCode()
-        {
-            var hash = 1;
-            if (Error.Length != 0) hash ^= Error.GetHashCode();
-            if (Hash.Length != 0) hash ^= Hash.GetHashCode();
-            if (settings_ != null) hash ^= Settings.GetHashCode();
-            return hash;
-        }
-
-        partial void OnConstruction();
-
-        public override string ToString()
-        {
-            return pb::JsonFormatter.ToDiagnosticString(this);
-        }
-    }
-
-    [global::System.Diagnostics.DebuggerNonUserCodeAttribute()]
-    public sealed partial class GlobalSettings : pb::IMessage<GlobalSettings>
-    {
-        /// <summary>Field number for the "fort_settings" field.</summary>
-        public const int FortSettingsFieldNumber = 2;
-
-        /// <summary>Field number for the "map_settings" field.</summary>
-        public const int MapSettingsFieldNumber = 3;
-
-        /// <summary>Field number for the "level_settings" field.</summary>
-        public const int LevelSettingsFieldNumber = 4;
-
-        /// <summary>Field number for the "inventory_settings" field.</summary>
-        public const int InventorySettingsFieldNumber = 5;
-
-        /// <summary>Field number for the "minimum_client_version" field.</summary>
-        public const int MinimumClientVersionFieldNumber = 6;
-
-        private static readonly pb::MessageParser<GlobalSettings> _parser =
-            new pb::MessageParser<GlobalSettings>(() => new GlobalSettings());
-
-        private global::PokemonGo.RocketAPI.GeneratedCode.FortSettings fortSettings_;
-        private global::PokemonGo.RocketAPI.GeneratedCode.InventorySettings inventorySettings_;
-        private global::PokemonGo.RocketAPI.GeneratedCode.LevelSettings levelSettings_;
-        private global::PokemonGo.RocketAPI.GeneratedCode.MapSettings mapSettings_;
-        private string minimumClientVersion_ = "";
-
-        public GlobalSettings()
-        {
-            OnConstruction();
-        }
-
-        public GlobalSettings(GlobalSettings other) : this()
-        {
-            FortSettings = other.fortSettings_ != null ? other.FortSettings.Clone() : null;
-            MapSettings = other.mapSettings_ != null ? other.MapSettings.Clone() : null;
-            LevelSettings = other.levelSettings_ != null ? other.LevelSettings.Clone() : null;
-            InventorySettings = other.inventorySettings_ != null ? other.InventorySettings.Clone() : null;
-            minimumClientVersion_ = other.minimumClientVersion_;
-        }
-
-        public static pb::MessageParser<GlobalSettings> Parser
-        {
-            get { return _parser; }
-        }
-
-        public static pbr::MessageDescriptor Descriptor
-        {
-            get { return global::PokemonGo.RocketAPI.GeneratedCode.PayloadsReflection.Descriptor.MessageTypes[36]; }
-        }
-
-        public global::PokemonGo.RocketAPI.GeneratedCode.FortSettings FortSettings
-        {
-            get { return fortSettings_; }
-            set { fortSettings_ = value; }
-        }
-
-        public global::PokemonGo.RocketAPI.GeneratedCode.MapSettings MapSettings
-        {
-            get { return mapSettings_; }
-            set { mapSettings_ = value; }
-        }
-
-        public global::PokemonGo.RocketAPI.GeneratedCode.LevelSettings LevelSettings
-        {
-            get { return levelSettings_; }
-            set { levelSettings_ = value; }
-        }
-
-        public global::PokemonGo.RocketAPI.GeneratedCode.InventorySettings InventorySettings
-        {
-            get { return inventorySettings_; }
-            set { inventorySettings_ = value; }
-        }
-
-        public string MinimumClientVersion
-        {
-            get { return minimumClientVersion_; }
-            set { minimumClientVersion_ = pb::ProtoPreconditions.CheckNotNull(value, "value"); }
-        }
-
-        pbr::MessageDescriptor pb::IMessage.Descriptor
-        {
-            get { return Descriptor; }
-        }
-
-        public GlobalSettings Clone()
-        {
-            return new GlobalSettings(this);
-        }
-
-        public bool Equals(GlobalSettings other)
-        {
-            if (ReferenceEquals(other, null))
-            {
-                return false;
-            }
-            if (ReferenceEquals(other, this))
-            {
-                return true;
-            }
-            if (!Equals(FortSettings, other.FortSettings)) return false;
-            if (!Equals(MapSettings, other.MapSettings)) return false;
-            if (!Equals(LevelSettings, other.LevelSettings)) return false;
-            if (!Equals(InventorySettings, other.InventorySettings)) return false;
-            if (MinimumClientVersion != other.MinimumClientVersion) return false;
-            return true;
-        }
-
-        public void WriteTo(pb::CodedOutputStream output)
-        {
-            if (fortSettings_ != null)
-            {
-                output.WriteRawTag(18);
-                output.WriteMessage(FortSettings);
-            }
-            if (mapSettings_ != null)
-            {
-                output.WriteRawTag(26);
-                output.WriteMessage(MapSettings);
-            }
-            if (levelSettings_ != null)
-            {
-                output.WriteRawTag(34);
-                output.WriteMessage(LevelSettings);
-            }
-            if (inventorySettings_ != null)
-            {
-                output.WriteRawTag(42);
-                output.WriteMessage(InventorySettings);
-            }
-            if (MinimumClientVersion.Length != 0)
-            {
-                output.WriteRawTag(50);
-                output.WriteString(MinimumClientVersion);
-            }
-        }
-
-        public int CalculateSize()
-        {
-            var size = 0;
-            if (fortSettings_ != null)
-            {
-                size += 1 + pb::CodedOutputStream.ComputeMessageSize(FortSettings);
-            }
-            if (mapSettings_ != null)
-            {
-                size += 1 + pb::CodedOutputStream.ComputeMessageSize(MapSettings);
-            }
-            if (levelSettings_ != null)
-            {
-                size += 1 + pb::CodedOutputStream.ComputeMessageSize(LevelSettings);
-            }
-            if (inventorySettings_ != null)
-            {
-                size += 1 + pb::CodedOutputStream.ComputeMessageSize(InventorySettings);
-            }
-            if (MinimumClientVersion.Length != 0)
-            {
-                size += 1 + pb::CodedOutputStream.ComputeStringSize(MinimumClientVersion);
-            }
-            return size;
-        }
-
-        public void MergeFrom(GlobalSettings other)
-        {
-            if (other == null)
-            {
-                return;
-            }
-            if (other.fortSettings_ != null)
-            {
-                if (fortSettings_ == null)
-                {
-                    fortSettings_ = new global::PokemonGo.RocketAPI.GeneratedCode.FortSettings();
-                }
-                FortSettings.MergeFrom(other.FortSettings);
-            }
-            if (other.mapSettings_ != null)
-            {
-                if (mapSettings_ == null)
-                {
-                    mapSettings_ = new global::PokemonGo.RocketAPI.GeneratedCode.MapSettings();
-                }
-                MapSettings.MergeFrom(other.MapSettings);
-            }
-            if (other.levelSettings_ != null)
-            {
-                if (levelSettings_ == null)
-                {
-                    levelSettings_ = new global::PokemonGo.RocketAPI.GeneratedCode.LevelSettings();
-                }
-                LevelSettings.MergeFrom(other.LevelSettings);
-            }
-            if (other.inventorySettings_ != null)
-            {
-                if (inventorySettings_ == null)
-                {
-                    inventorySettings_ = new global::PokemonGo.RocketAPI.GeneratedCode.InventorySettings();
-                }
-                InventorySettings.MergeFrom(other.InventorySettings);
-            }
-            if (other.MinimumClientVersion.Length != 0)
-            {
-                MinimumClientVersion = other.MinimumClientVersion;
-            }
-        }
-
-        public void MergeFrom(pb::CodedInputStream input)
-        {
-            uint tag;
-            while ((tag = input.ReadTag()) != 0)
-            {
-                switch (tag)
-                {
-                    default:
-                        input.SkipLastField();
-                        break;
-                    case 18:
-                        {
-                            if (fortSettings_ == null)
-                            {
-                                fortSettings_ = new global::PokemonGo.RocketAPI.GeneratedCode.FortSettings();
-                            }
-                            input.ReadMessage(fortSettings_);
-                            break;
-                        }
-                    case 26:
-                        {
-                            if (mapSettings_ == null)
-                            {
-                                mapSettings_ = new global::PokemonGo.RocketAPI.GeneratedCode.MapSettings();
-                            }
-                            input.ReadMessage(mapSettings_);
-                            break;
-                        }
-                    case 34:
-                        {
-                            if (levelSettings_ == null)
-                            {
-                                levelSettings_ = new global::PokemonGo.RocketAPI.GeneratedCode.LevelSettings();
-                            }
-                            input.ReadMessage(levelSettings_);
-                            break;
-                        }
-                    case 42:
-                        {
-                            if (inventorySettings_ == null)
-                            {
-                                inventorySettings_ = new global::PokemonGo.RocketAPI.GeneratedCode.InventorySettings();
-                            }
-                            input.ReadMessage(inventorySettings_);
-                            break;
-                        }
-                    case 50:
-                        {
-                            MinimumClientVersion = input.ReadString();
-                            break;
-                        }
-                }
-            }
-        }
-
-        public override bool Equals(object other)
-        {
-            return Equals(other as GlobalSettings);
-        }
-
-        public override int GetHashCode()
-        {
-            var hash = 1;
-            if (fortSettings_ != null) hash ^= FortSettings.GetHashCode();
-            if (mapSettings_ != null) hash ^= MapSettings.GetHashCode();
-            if (levelSettings_ != null) hash ^= LevelSettings.GetHashCode();
-            if (inventorySettings_ != null) hash ^= InventorySettings.GetHashCode();
-            if (MinimumClientVersion.Length != 0) hash ^= MinimumClientVersion.GetHashCode();
-            return hash;
-        }
-
-        partial void OnConstruction();
-
-        public override string ToString()
-        {
-            return pb::JsonFormatter.ToDiagnosticString(this);
-        }
-    }
-
-    [global::System.Diagnostics.DebuggerNonUserCodeAttribute()]
-    public sealed partial class FortSettings : pb::IMessage<FortSettings>
-    {
-        /// <summary>Field number for the "interaction_range_meters" field.</summary>
-        public const int InteractionRangeMetersFieldNumber = 1;
-
-        /// <summary>Field number for the "max_total_deployed_pokemon" field.</summary>
-        public const int MaxTotalDeployedPokemonFieldNumber = 2;
-
-        /// <summary>Field number for the "max_player_deployed_pokemon" field.</summary>
-        public const int MaxPlayerDeployedPokemonFieldNumber = 3;
-
-        /// <summary>Field number for the "deploy_stamina_multiplier" field.</summary>
-        public const int DeployStaminaMultiplierFieldNumber = 4;
-
-        /// <summary>Field number for the "deploy_attack_multiplier" field.</summary>
-        public const int DeployAttackMultiplierFieldNumber = 5;
-
-        /// <summary>Field number for the "far_interaction_range_meters" field.</summary>
-        public const int FarInteractionRangeMetersFieldNumber = 6;
-
-        private static readonly pb::MessageParser<FortSettings> _parser =
-            new pb::MessageParser<FortSettings>(() => new FortSettings());
-
-        private double deployAttackMultiplier_;
-        private double deployStaminaMultiplier_;
-        private double farInteractionRangeMeters_;
-        private double interactionRangeMeters_;
-        private int maxPlayerDeployedPokemon_;
-        private int maxTotalDeployedPokemon_;
-
-        public FortSettings()
-        {
-            OnConstruction();
-        }
-
-        public FortSettings(FortSettings other) : this()
-        {
-            interactionRangeMeters_ = other.interactionRangeMeters_;
-            maxTotalDeployedPokemon_ = other.maxTotalDeployedPokemon_;
-            maxPlayerDeployedPokemon_ = other.maxPlayerDeployedPokemon_;
-            deployStaminaMultiplier_ = other.deployStaminaMultiplier_;
-            deployAttackMultiplier_ = other.deployAttackMultiplier_;
-            farInteractionRangeMeters_ = other.farInteractionRangeMeters_;
-        }
-
-        public static pb::MessageParser<FortSettings> Parser
-        {
-            get { return _parser; }
-        }
-
-        public static pbr::MessageDescriptor Descriptor
-        {
-            get { return global::PokemonGo.RocketAPI.GeneratedCode.PayloadsReflection.Descriptor.MessageTypes[37]; }
-        }
-
-        public double InteractionRangeMeters
-        {
-            get { return interactionRangeMeters_; }
-            set { interactionRangeMeters_ = value; }
-        }
-
-        public int MaxTotalDeployedPokemon
-        {
-            get { return maxTotalDeployedPokemon_; }
-            set { maxTotalDeployedPokemon_ = value; }
-        }
-
-        public int MaxPlayerDeployedPokemon
-        {
-            get { return maxPlayerDeployedPokemon_; }
-            set { maxPlayerDeployedPokemon_ = value; }
-        }
-
-        public double DeployStaminaMultiplier
-        {
-            get { return deployStaminaMultiplier_; }
-            set { deployStaminaMultiplier_ = value; }
-        }
-
-        public double DeployAttackMultiplier
-        {
-            get { return deployAttackMultiplier_; }
-            set { deployAttackMultiplier_ = value; }
-        }
-
-        public double FarInteractionRangeMeters
-        {
-            get { return farInteractionRangeMeters_; }
-            set { farInteractionRangeMeters_ = value; }
-        }
-
-        pbr::MessageDescriptor pb::IMessage.Descriptor
-        {
-            get { return Descriptor; }
-        }
-
-        public FortSettings Clone()
-        {
-            return new FortSettings(this);
-        }
-
-        public bool Equals(FortSettings other)
-        {
-            if (ReferenceEquals(other, null))
-            {
-                return false;
-            }
-            if (ReferenceEquals(other, this))
-            {
-                return true;
-            }
-            if (InteractionRangeMeters != other.InteractionRangeMeters) return false;
-            if (MaxTotalDeployedPokemon != other.MaxTotalDeployedPokemon) return false;
-            if (MaxPlayerDeployedPokemon != other.MaxPlayerDeployedPokemon) return false;
-            if (DeployStaminaMultiplier != other.DeployStaminaMultiplier) return false;
-            if (DeployAttackMultiplier != other.DeployAttackMultiplier) return false;
-            if (FarInteractionRangeMeters != other.FarInteractionRangeMeters) return false;
-            return true;
-        }
-
-        public void WriteTo(pb::CodedOutputStream output)
-        {
-            if (InteractionRangeMeters != 0D)
-            {
-                output.WriteRawTag(9);
-                output.WriteDouble(InteractionRangeMeters);
-            }
-            if (MaxTotalDeployedPokemon != 0)
-            {
-                output.WriteRawTag(16);
-                output.WriteInt32(MaxTotalDeployedPokemon);
-            }
-            if (MaxPlayerDeployedPokemon != 0)
-            {
-                output.WriteRawTag(24);
-                output.WriteInt32(MaxPlayerDeployedPokemon);
-            }
-            if (DeployStaminaMultiplier != 0D)
-            {
-                output.WriteRawTag(33);
-                output.WriteDouble(DeployStaminaMultiplier);
-            }
-            if (DeployAttackMultiplier != 0D)
-            {
-                output.WriteRawTag(41);
-                output.WriteDouble(DeployAttackMultiplier);
-            }
-            if (FarInteractionRangeMeters != 0D)
-            {
-                output.WriteRawTag(49);
-                output.WriteDouble(FarInteractionRangeMeters);
-            }
-        }
-
-        public int CalculateSize()
-        {
-            var size = 0;
-            if (InteractionRangeMeters != 0D)
-            {
-                size += 1 + 8;
-            }
-            if (MaxTotalDeployedPokemon != 0)
-            {
-                size += 1 + pb::CodedOutputStream.ComputeInt32Size(MaxTotalDeployedPokemon);
-            }
-            if (MaxPlayerDeployedPokemon != 0)
-            {
-                size += 1 + pb::CodedOutputStream.ComputeInt32Size(MaxPlayerDeployedPokemon);
-            }
-            if (DeployStaminaMultiplier != 0D)
-            {
-                size += 1 + 8;
-            }
-            if (DeployAttackMultiplier != 0D)
-            {
-                size += 1 + 8;
-            }
-            if (FarInteractionRangeMeters != 0D)
-            {
-                size += 1 + 8;
-            }
-            return size;
-        }
-
-        public void MergeFrom(FortSettings other)
-        {
-            if (other == null)
-            {
-                return;
-            }
-            if (other.InteractionRangeMeters != 0D)
-            {
-                InteractionRangeMeters = other.InteractionRangeMeters;
-            }
-            if (other.MaxTotalDeployedPokemon != 0)
-            {
-                MaxTotalDeployedPokemon = other.MaxTotalDeployedPokemon;
-            }
-            if (other.MaxPlayerDeployedPokemon != 0)
-            {
-                MaxPlayerDeployedPokemon = other.MaxPlayerDeployedPokemon;
-            }
-            if (other.DeployStaminaMultiplier != 0D)
-            {
-                DeployStaminaMultiplier = other.DeployStaminaMultiplier;
-            }
-            if (other.DeployAttackMultiplier != 0D)
-            {
-                DeployAttackMultiplier = other.DeployAttackMultiplier;
-            }
-            if (other.FarInteractionRangeMeters != 0D)
-            {
-                FarInteractionRangeMeters = other.FarInteractionRangeMeters;
-            }
-        }
-
-        public void MergeFrom(pb::CodedInputStream input)
-        {
-            uint tag;
-            while ((tag = input.ReadTag()) != 0)
-            {
-                switch (tag)
-                {
-                    default:
-                        input.SkipLastField();
-                        break;
-                    case 9:
-                        {
-                            InteractionRangeMeters = input.ReadDouble();
-                            break;
-                        }
-                    case 16:
-                        {
-                            MaxTotalDeployedPokemon = input.ReadInt32();
-                            break;
-                        }
-                    case 24:
-                        {
-                            MaxPlayerDeployedPokemon = input.ReadInt32();
-                            break;
-                        }
-                    case 33:
-                        {
-                            DeployStaminaMultiplier = input.ReadDouble();
-                            break;
-                        }
-                    case 41:
-                        {
-                            DeployAttackMultiplier = input.ReadDouble();
-                            break;
-                        }
-                    case 49:
-                        {
-                            FarInteractionRangeMeters = input.ReadDouble();
-                            break;
-                        }
-                }
-            }
-        }
-
-        public override bool Equals(object other)
-        {
-            return Equals(other as FortSettings);
-        }
-
-        public override int GetHashCode()
-        {
-            var hash = 1;
-            if (InteractionRangeMeters != 0D) hash ^= InteractionRangeMeters.GetHashCode();
-            if (MaxTotalDeployedPokemon != 0) hash ^= MaxTotalDeployedPokemon.GetHashCode();
-            if (MaxPlayerDeployedPokemon != 0) hash ^= MaxPlayerDeployedPokemon.GetHashCode();
-            if (DeployStaminaMultiplier != 0D) hash ^= DeployStaminaMultiplier.GetHashCode();
-            if (DeployAttackMultiplier != 0D) hash ^= DeployAttackMultiplier.GetHashCode();
-            if (FarInteractionRangeMeters != 0D) hash ^= FarInteractionRangeMeters.GetHashCode();
-            return hash;
-        }
-
-        partial void OnConstruction();
-
-        public override string ToString()
-        {
-            return pb::JsonFormatter.ToDiagnosticString(this);
-        }
-    }
-
-    [global::System.Diagnostics.DebuggerNonUserCodeAttribute()]
-    public sealed partial class MapSettings : pb::IMessage<MapSettings>
-    {
-        /// <summary>Field number for the "pokemon_visible_range" field.</summary>
-        public const int PokemonVisibleRangeFieldNumber = 1;
-
-        /// <summary>Field number for the "poke_nav_range_meters" field.</summary>
-        public const int PokeNavRangeMetersFieldNumber = 2;
-
-        /// <summary>Field number for the "encounter_range_meters" field.</summary>
-        public const int EncounterRangeMetersFieldNumber = 3;
-
-        /// <summary>Field number for the "get_map_objects_min_refresh_seconds" field.</summary>
-        public const int GetMapObjectsMinRefreshSecondsFieldNumber = 4;
-
-        /// <summary>Field number for the "get_map_objects_max_refresh_seconds" field.</summary>
-        public const int GetMapObjectsMaxRefreshSecondsFieldNumber = 5;
-
-        /// <summary>Field number for the "get_map_objects_min_distance_meters" field.</summary>
-        public const int GetMapObjectsMinDistanceMetersFieldNumber = 6;
-
-        /// <summary>Field number for the "google_maps_api_key" field.</summary>
-        public const int GoogleMapsApiKeyFieldNumber = 7;
-
-        private static readonly pb::MessageParser<MapSettings> _parser =
-            new pb::MessageParser<MapSettings>(() => new MapSettings());
-
-        private double encounterRangeMeters_;
-        private float getMapObjectsMaxRefreshSeconds_;
-        private float getMapObjectsMinDistanceMeters_;
-        private float getMapObjectsMinRefreshSeconds_;
-        private string googleMapsApiKey_ = "";
-        private double pokemonVisibleRange_;
-        private double pokeNavRangeMeters_;
-
-        public MapSettings()
-        {
-            OnConstruction();
-        }
-
-        public MapSettings(MapSettings other) : this()
-        {
-            pokemonVisibleRange_ = other.pokemonVisibleRange_;
-            pokeNavRangeMeters_ = other.pokeNavRangeMeters_;
-            encounterRangeMeters_ = other.encounterRangeMeters_;
-            getMapObjectsMinRefreshSeconds_ = other.getMapObjectsMinRefreshSeconds_;
-            getMapObjectsMaxRefreshSeconds_ = other.getMapObjectsMaxRefreshSeconds_;
-            getMapObjectsMinDistanceMeters_ = other.getMapObjectsMinDistanceMeters_;
-            googleMapsApiKey_ = other.googleMapsApiKey_;
-        }
-
-        public static pb::MessageParser<MapSettings> Parser
-        {
-            get { return _parser; }
-        }
-
-        public static pbr::MessageDescriptor Descriptor
-        {
-            get { return global::PokemonGo.RocketAPI.GeneratedCode.PayloadsReflection.Descriptor.MessageTypes[38]; }
-        }
-
-        public double PokemonVisibleRange
-        {
-            get { return pokemonVisibleRange_; }
-            set { pokemonVisibleRange_ = value; }
-        }
-
-        public double PokeNavRangeMeters
-        {
-            get { return pokeNavRangeMeters_; }
-            set { pokeNavRangeMeters_ = value; }
-        }
-
-        public double EncounterRangeMeters
-        {
-            get { return encounterRangeMeters_; }
-            set { encounterRangeMeters_ = value; }
-        }
-
-        public float GetMapObjectsMinRefreshSeconds
-        {
-            get { return getMapObjectsMinRefreshSeconds_; }
-            set { getMapObjectsMinRefreshSeconds_ = value; }
-        }
-
-        public float GetMapObjectsMaxRefreshSeconds
-        {
-            get { return getMapObjectsMaxRefreshSeconds_; }
-            set { getMapObjectsMaxRefreshSeconds_ = value; }
-        }
-
-        public float GetMapObjectsMinDistanceMeters
-        {
-            get { return getMapObjectsMinDistanceMeters_; }
-            set { getMapObjectsMinDistanceMeters_ = value; }
-        }
-
-        public string GoogleMapsApiKey
-        {
-            get { return googleMapsApiKey_; }
-            set { googleMapsApiKey_ = pb::ProtoPreconditions.CheckNotNull(value, "value"); }
-        }
-
-        pbr::MessageDescriptor pb::IMessage.Descriptor
-        {
-            get { return Descriptor; }
-        }
-
-        public MapSettings Clone()
-        {
-            return new MapSettings(this);
-        }
-
-        public bool Equals(MapSettings other)
-        {
-            if (ReferenceEquals(other, null))
-            {
-                return false;
-            }
-            if (ReferenceEquals(other, this))
-            {
-                return true;
-            }
-            if (PokemonVisibleRange != other.PokemonVisibleRange) return false;
-            if (PokeNavRangeMeters != other.PokeNavRangeMeters) return false;
-            if (EncounterRangeMeters != other.EncounterRangeMeters) return false;
-            if (GetMapObjectsMinRefreshSeconds != other.GetMapObjectsMinRefreshSeconds) return false;
-            if (GetMapObjectsMaxRefreshSeconds != other.GetMapObjectsMaxRefreshSeconds) return false;
-            if (GetMapObjectsMinDistanceMeters != other.GetMapObjectsMinDistanceMeters) return false;
-            if (GoogleMapsApiKey != other.GoogleMapsApiKey) return false;
-            return true;
-        }
-
-        public void WriteTo(pb::CodedOutputStream output)
-        {
-            if (PokemonVisibleRange != 0D)
-            {
-                output.WriteRawTag(9);
-                output.WriteDouble(PokemonVisibleRange);
-            }
-            if (PokeNavRangeMeters != 0D)
-            {
-                output.WriteRawTag(17);
-                output.WriteDouble(PokeNavRangeMeters);
-            }
-            if (EncounterRangeMeters != 0D)
-            {
-                output.WriteRawTag(25);
-                output.WriteDouble(EncounterRangeMeters);
-            }
-            if (GetMapObjectsMinRefreshSeconds != 0F)
-            {
-                output.WriteRawTag(37);
-                output.WriteFloat(GetMapObjectsMinRefreshSeconds);
-            }
-            if (GetMapObjectsMaxRefreshSeconds != 0F)
-            {
-                output.WriteRawTag(45);
-                output.WriteFloat(GetMapObjectsMaxRefreshSeconds);
-            }
-            if (GetMapObjectsMinDistanceMeters != 0F)
-            {
-                output.WriteRawTag(53);
-                output.WriteFloat(GetMapObjectsMinDistanceMeters);
-            }
-            if (GoogleMapsApiKey.Length != 0)
-            {
-                output.WriteRawTag(58);
-                output.WriteString(GoogleMapsApiKey);
-            }
-        }
-
-        public int CalculateSize()
-        {
-            var size = 0;
-            if (PokemonVisibleRange != 0D)
-            {
-                size += 1 + 8;
-            }
-            if (PokeNavRangeMeters != 0D)
-            {
-                size += 1 + 8;
-            }
-            if (EncounterRangeMeters != 0D)
-            {
-                size += 1 + 8;
-            }
-            if (GetMapObjectsMinRefreshSeconds != 0F)
-            {
-                size += 1 + 4;
-            }
-            if (GetMapObjectsMaxRefreshSeconds != 0F)
-            {
-                size += 1 + 4;
-            }
-            if (GetMapObjectsMinDistanceMeters != 0F)
-            {
-                size += 1 + 4;
-            }
-            if (GoogleMapsApiKey.Length != 0)
-            {
-                size += 1 + pb::CodedOutputStream.ComputeStringSize(GoogleMapsApiKey);
-            }
-            return size;
-        }
-
-        public void MergeFrom(MapSettings other)
-        {
-            if (other == null)
-            {
-                return;
-            }
-            if (other.PokemonVisibleRange != 0D)
-            {
-                PokemonVisibleRange = other.PokemonVisibleRange;
-            }
-            if (other.PokeNavRangeMeters != 0D)
-            {
-                PokeNavRangeMeters = other.PokeNavRangeMeters;
-            }
-            if (other.EncounterRangeMeters != 0D)
-            {
-                EncounterRangeMeters = other.EncounterRangeMeters;
-            }
-            if (other.GetMapObjectsMinRefreshSeconds != 0F)
-            {
-                GetMapObjectsMinRefreshSeconds = other.GetMapObjectsMinRefreshSeconds;
-            }
-            if (other.GetMapObjectsMaxRefreshSeconds != 0F)
-            {
-                GetMapObjectsMaxRefreshSeconds = other.GetMapObjectsMaxRefreshSeconds;
-            }
-            if (other.GetMapObjectsMinDistanceMeters != 0F)
-            {
-                GetMapObjectsMinDistanceMeters = other.GetMapObjectsMinDistanceMeters;
-            }
-            if (other.GoogleMapsApiKey.Length != 0)
-            {
-                GoogleMapsApiKey = other.GoogleMapsApiKey;
-            }
-        }
-
-        public void MergeFrom(pb::CodedInputStream input)
-        {
-            uint tag;
-            while ((tag = input.ReadTag()) != 0)
-            {
-                switch (tag)
-                {
-                    default:
-                        input.SkipLastField();
-                        break;
-                    case 9:
-                        {
-                            PokemonVisibleRange = input.ReadDouble();
-                            break;
-                        }
-                    case 17:
-                        {
-                            PokeNavRangeMeters = input.ReadDouble();
-                            break;
-                        }
-                    case 25:
-                        {
-                            EncounterRangeMeters = input.ReadDouble();
-                            break;
-                        }
-                    case 37:
-                        {
-                            GetMapObjectsMinRefreshSeconds = input.ReadFloat();
-                            break;
-                        }
-                    case 45:
-                        {
-                            GetMapObjectsMaxRefreshSeconds = input.ReadFloat();
-                            break;
-                        }
-                    case 53:
-                        {
-                            GetMapObjectsMinDistanceMeters = input.ReadFloat();
-                            break;
-                        }
-                    case 58:
-                        {
-                            GoogleMapsApiKey = input.ReadString();
-                            break;
-                        }
-                }
-            }
-        }
-
-        public override bool Equals(object other)
-        {
-            return Equals(other as MapSettings);
-        }
-
-        public override int GetHashCode()
-        {
-            var hash = 1;
-            if (PokemonVisibleRange != 0D) hash ^= PokemonVisibleRange.GetHashCode();
-            if (PokeNavRangeMeters != 0D) hash ^= PokeNavRangeMeters.GetHashCode();
-            if (EncounterRangeMeters != 0D) hash ^= EncounterRangeMeters.GetHashCode();
-            if (GetMapObjectsMinRefreshSeconds != 0F) hash ^= GetMapObjectsMinRefreshSeconds.GetHashCode();
-            if (GetMapObjectsMaxRefreshSeconds != 0F) hash ^= GetMapObjectsMaxRefreshSeconds.GetHashCode();
-            if (GetMapObjectsMinDistanceMeters != 0F) hash ^= GetMapObjectsMinDistanceMeters.GetHashCode();
-            if (GoogleMapsApiKey.Length != 0) hash ^= GoogleMapsApiKey.GetHashCode();
-            return hash;
-        }
-
-        partial void OnConstruction();
-
-        public override string ToString()
-        {
-            return pb::JsonFormatter.ToDiagnosticString(this);
-        }
-    }
-
-    [global::System.Diagnostics.DebuggerNonUserCodeAttribute()]
-    public sealed partial class LevelSettings : pb::IMessage<LevelSettings>
-    {
-        /// <summary>Field number for the "trainer_cp_modifier" field.</summary>
-        public const int TrainerCpModifierFieldNumber = 2;
-
-        /// <summary>Field number for the "trainer_difficulty_modifier" field.</summary>
-        public const int TrainerDifficultyModifierFieldNumber = 3;
-
-        private static readonly pb::MessageParser<LevelSettings> _parser =
-            new pb::MessageParser<LevelSettings>(() => new LevelSettings());
-
-        private double trainerCpModifier_;
-        private double trainerDifficultyModifier_;
-
-        public LevelSettings()
-        {
-            OnConstruction();
-        }
-
-        public LevelSettings(LevelSettings other) : this()
-        {
-            trainerCpModifier_ = other.trainerCpModifier_;
-            trainerDifficultyModifier_ = other.trainerDifficultyModifier_;
-        }
-
-        public static pb::MessageParser<LevelSettings> Parser
-        {
-            get { return _parser; }
-        }
-
-        public static pbr::MessageDescriptor Descriptor
-        {
-            get { return global::PokemonGo.RocketAPI.GeneratedCode.PayloadsReflection.Descriptor.MessageTypes[39]; }
-        }
-
-        public double TrainerCpModifier
-        {
-            get { return trainerCpModifier_; }
-            set { trainerCpModifier_ = value; }
-        }
-
-        public double TrainerDifficultyModifier
-        {
-            get { return trainerDifficultyModifier_; }
-            set { trainerDifficultyModifier_ = value; }
-        }
-
-        pbr::MessageDescriptor pb::IMessage.Descriptor
-        {
-            get { return Descriptor; }
-        }
-
-        public LevelSettings Clone()
-        {
-            return new LevelSettings(this);
-        }
-
-        public bool Equals(LevelSettings other)
-        {
-            if (ReferenceEquals(other, null))
-            {
-                return false;
-            }
-            if (ReferenceEquals(other, this))
-            {
-                return true;
-            }
-            if (TrainerCpModifier != other.TrainerCpModifier) return false;
-            if (TrainerDifficultyModifier != other.TrainerDifficultyModifier) return false;
-            return true;
-        }
-
-        public void WriteTo(pb::CodedOutputStream output)
-        {
-            if (TrainerCpModifier != 0D)
-            {
-                output.WriteRawTag(17);
-                output.WriteDouble(TrainerCpModifier);
-            }
-            if (TrainerDifficultyModifier != 0D)
-            {
-                output.WriteRawTag(25);
-                output.WriteDouble(TrainerDifficultyModifier);
-            }
-        }
-
-        public int CalculateSize()
-        {
-            var size = 0;
-            if (TrainerCpModifier != 0D)
-            {
-                size += 1 + 8;
-            }
-            if (TrainerDifficultyModifier != 0D)
-            {
-                size += 1 + 8;
-            }
-            return size;
-        }
-
-        public void MergeFrom(LevelSettings other)
-        {
-            if (other == null)
-            {
-                return;
-            }
-            if (other.TrainerCpModifier != 0D)
-            {
-                TrainerCpModifier = other.TrainerCpModifier;
-            }
-            if (other.TrainerDifficultyModifier != 0D)
-            {
-                TrainerDifficultyModifier = other.TrainerDifficultyModifier;
-            }
-        }
-
-        public void MergeFrom(pb::CodedInputStream input)
-        {
-            uint tag;
-            while ((tag = input.ReadTag()) != 0)
-            {
-                switch (tag)
-                {
-                    default:
-                        input.SkipLastField();
-                        break;
-                    case 17:
-                        {
-                            TrainerCpModifier = input.ReadDouble();
-                            break;
-                        }
-                    case 25:
-                        {
-                            TrainerDifficultyModifier = input.ReadDouble();
-                            break;
-                        }
-                }
-            }
-        }
-
-        public override bool Equals(object other)
-        {
-            return Equals(other as LevelSettings);
-        }
-
-        public override int GetHashCode()
-        {
-            var hash = 1;
-            if (TrainerCpModifier != 0D) hash ^= TrainerCpModifier.GetHashCode();
-            if (TrainerDifficultyModifier != 0D) hash ^= TrainerDifficultyModifier.GetHashCode();
-            return hash;
-        }
-
-        partial void OnConstruction();
-
-        public override string ToString()
-        {
-            return pb::JsonFormatter.ToDiagnosticString(this);
-        }
-    }
-
-    [global::System.Diagnostics.DebuggerNonUserCodeAttribute()]
-    public sealed partial class InventorySettings : pb::IMessage<InventorySettings>
-    {
-        /// <summary>Field number for the "max_pokemon" field.</summary>
-        public const int MaxPokemonFieldNumber = 1;
-
-        /// <summary>Field number for the "max_bag_items" field.</summary>
-        public const int MaxBagItemsFieldNumber = 2;
-
-        /// <summary>Field number for the "base_pokemon" field.</summary>
-        public const int BasePokemonFieldNumber = 3;
-
-        /// <summary>Field number for the "base_bag_items" field.</summary>
-        public const int BaseBagItemsFieldNumber = 4;
-
-        /// <summary>Field number for the "base_eggs" field.</summary>
-        public const int BaseEggsFieldNumber = 5;
-
-        private static readonly pb::MessageParser<InventorySettings> _parser =
-            new pb::MessageParser<InventorySettings>(() => new InventorySettings());
-
-        private int baseBagItems_;
-        private int baseEggs_;
-        private int basePokemon_;
-        private int maxBagItems_;
-        private int maxPokemon_;
-
-        public InventorySettings()
-        {
-            OnConstruction();
-        }
-
-        public InventorySettings(InventorySettings other) : this()
-        {
-            maxPokemon_ = other.maxPokemon_;
-            maxBagItems_ = other.maxBagItems_;
-            basePokemon_ = other.basePokemon_;
-            baseBagItems_ = other.baseBagItems_;
-            baseEggs_ = other.baseEggs_;
-        }
-
-        public static pb::MessageParser<InventorySettings> Parser
-        {
-            get { return _parser; }
-        }
-
-        public static pbr::MessageDescriptor Descriptor
-        {
-            get { return global::PokemonGo.RocketAPI.GeneratedCode.PayloadsReflection.Descriptor.MessageTypes[40]; }
-        }
-
-        public int MaxPokemon
-        {
-            get { return maxPokemon_; }
-            set { maxPokemon_ = value; }
-        }
-
-        public int MaxBagItems
-        {
-            get { return maxBagItems_; }
-            set { maxBagItems_ = value; }
-        }
-
-        public int BasePokemon
-        {
-            get { return basePokemon_; }
-            set { basePokemon_ = value; }
-        }
-
-        public int BaseBagItems
-        {
-            get { return baseBagItems_; }
-            set { baseBagItems_ = value; }
-        }
-
-        public int BaseEggs
-        {
-            get { return baseEggs_; }
-            set { baseEggs_ = value; }
-        }
-
-        pbr::MessageDescriptor pb::IMessage.Descriptor
-        {
-            get { return Descriptor; }
-        }
-
-        public InventorySettings Clone()
-        {
-            return new InventorySettings(this);
-        }
-
-        public bool Equals(InventorySettings other)
-        {
-            if (ReferenceEquals(other, null))
-            {
-                return false;
-            }
-            if (ReferenceEquals(other, this))
-            {
-                return true;
-            }
-            if (MaxPokemon != other.MaxPokemon) return false;
-            if (MaxBagItems != other.MaxBagItems) return false;
-            if (BasePokemon != other.BasePokemon) return false;
-            if (BaseBagItems != other.BaseBagItems) return false;
-            if (BaseEggs != other.BaseEggs) return false;
-            return true;
-        }
-
-        public void WriteTo(pb::CodedOutputStream output)
-        {
-            if (MaxPokemon != 0)
-            {
-                output.WriteRawTag(8);
-                output.WriteInt32(MaxPokemon);
-            }
-            if (MaxBagItems != 0)
-            {
-                output.WriteRawTag(16);
-                output.WriteInt32(MaxBagItems);
-            }
-            if (BasePokemon != 0)
-            {
-                output.WriteRawTag(24);
-                output.WriteInt32(BasePokemon);
-            }
-            if (BaseBagItems != 0)
-            {
-                output.WriteRawTag(32);
-                output.WriteInt32(BaseBagItems);
-            }
-            if (BaseEggs != 0)
-            {
-                output.WriteRawTag(40);
-                output.WriteInt32(BaseEggs);
-            }
-        }
-
-        public int CalculateSize()
-        {
-            var size = 0;
-            if (MaxPokemon != 0)
-            {
-                size += 1 + pb::CodedOutputStream.ComputeInt32Size(MaxPokemon);
-            }
-            if (MaxBagItems != 0)
-            {
-                size += 1 + pb::CodedOutputStream.ComputeInt32Size(MaxBagItems);
-            }
-            if (BasePokemon != 0)
-            {
-                size += 1 + pb::CodedOutputStream.ComputeInt32Size(BasePokemon);
-            }
-            if (BaseBagItems != 0)
-            {
-                size += 1 + pb::CodedOutputStream.ComputeInt32Size(BaseBagItems);
-            }
-            if (BaseEggs != 0)
-            {
-                size += 1 + pb::CodedOutputStream.ComputeInt32Size(BaseEggs);
-            }
-            return size;
-        }
-
-        public void MergeFrom(InventorySettings other)
-        {
-            if (other == null)
-            {
-                return;
-            }
-            if (other.MaxPokemon != 0)
-            {
-                MaxPokemon = other.MaxPokemon;
-            }
-            if (other.MaxBagItems != 0)
-            {
-                MaxBagItems = other.MaxBagItems;
-            }
-            if (other.BasePokemon != 0)
-            {
-                BasePokemon = other.BasePokemon;
-            }
-            if (other.BaseBagItems != 0)
-            {
-                BaseBagItems = other.BaseBagItems;
-            }
-            if (other.BaseEggs != 0)
-            {
-                BaseEggs = other.BaseEggs;
-            }
-        }
-
-        public void MergeFrom(pb::CodedInputStream input)
-        {
-            uint tag;
-            while ((tag = input.ReadTag()) != 0)
-            {
-                switch (tag)
-                {
-                    default:
-                        input.SkipLastField();
-                        break;
-                    case 8:
-                        {
-                            MaxPokemon = input.ReadInt32();
-                            break;
-                        }
-                    case 16:
-                        {
-                            MaxBagItems = input.ReadInt32();
-                            break;
-                        }
-                    case 24:
-                        {
-                            BasePokemon = input.ReadInt32();
-                            break;
-                        }
-                    case 32:
-                        {
-                            BaseBagItems = input.ReadInt32();
-                            break;
-                        }
-                    case 40:
-                        {
-                            BaseEggs = input.ReadInt32();
-                            break;
-                        }
-                }
-            }
-        }
-
-        public override bool Equals(object other)
-        {
-            return Equals(other as InventorySettings);
-        }
-
-        public override int GetHashCode()
-        {
-            var hash = 1;
-            if (MaxPokemon != 0) hash ^= MaxPokemon.GetHashCode();
-            if (MaxBagItems != 0) hash ^= MaxBagItems.GetHashCode();
-            if (BasePokemon != 0) hash ^= BasePokemon.GetHashCode();
-            if (BaseBagItems != 0) hash ^= BaseBagItems.GetHashCode();
-            if (BaseEggs != 0) hash ^= BaseEggs.GetHashCode();
-            return hash;
-        }
-
-        partial void OnConstruction();
-
-        public override string ToString()
-        {
-            return pb::JsonFormatter.ToDiagnosticString(this);
-        }
-    }
-
-    [global::System.Diagnostics.DebuggerNonUserCodeAttribute()]
-    public sealed partial class PlayerUpdateRequest : pb::IMessage<PlayerUpdateRequest>
-    {
-        /// <summary>Field number for the "latitude" field.</summary>
-        public const int LatitudeFieldNumber = 1;
-
-        /// <summary>Field number for the "longitude" field.</summary>
-        public const int LongitudeFieldNumber = 2;
-
-        private static readonly pb::MessageParser<PlayerUpdateRequest> _parser =
-            new pb::MessageParser<PlayerUpdateRequest>(() => new PlayerUpdateRequest());
-
-        private double latitude_;
-        private double longitude_;
-
-        public PlayerUpdateRequest()
-        {
-            OnConstruction();
-        }
-
-        public PlayerUpdateRequest(PlayerUpdateRequest other) : this()
-        {
-            latitude_ = other.latitude_;
-            longitude_ = other.longitude_;
-        }
-
-        public static pb::MessageParser<PlayerUpdateRequest> Parser
-        {
-            get { return _parser; }
-        }
-
-        public static pbr::MessageDescriptor Descriptor
-        {
-            get { return global::PokemonGo.RocketAPI.GeneratedCode.PayloadsReflection.Descriptor.MessageTypes[41]; }
-        }
-
-        public double Latitude
-        {
-            get { return latitude_; }
-            set { latitude_ = value; }
-        }
-
-        public double Longitude
-        {
-            get { return longitude_; }
-            set { longitude_ = value; }
-        }
-
-        pbr::MessageDescriptor pb::IMessage.Descriptor
-        {
-            get { return Descriptor; }
-        }
-
-        public PlayerUpdateRequest Clone()
-        {
-            return new PlayerUpdateRequest(this);
-        }
-
-        public bool Equals(PlayerUpdateRequest other)
-        {
-            if (ReferenceEquals(other, null))
-            {
-                return false;
-            }
-            if (ReferenceEquals(other, this))
-            {
-                return true;
-            }
-            if (Latitude != other.Latitude) return false;
-            if (Longitude != other.Longitude) return false;
-            return true;
-        }
-
-        public void WriteTo(pb::CodedOutputStream output)
-        {
-            if (Latitude != 0D)
-            {
-                output.WriteRawTag(9);
-                output.WriteDouble(Latitude);
-            }
-            if (Longitude != 0D)
-            {
-                output.WriteRawTag(17);
-                output.WriteDouble(Longitude);
-            }
-        }
-
-        public int CalculateSize()
-        {
-            var size = 0;
-            if (Latitude != 0D)
-            {
-                size += 1 + 8;
-            }
-            if (Longitude != 0D)
-            {
-                size += 1 + 8;
-            }
-            return size;
-        }
-
-        public void MergeFrom(PlayerUpdateRequest other)
-        {
-            if (other == null)
-            {
-                return;
-            }
-            if (other.Latitude != 0D)
-            {
-                Latitude = other.Latitude;
-            }
-            if (other.Longitude != 0D)
-            {
-                Longitude = other.Longitude;
-            }
-        }
-
-        public void MergeFrom(pb::CodedInputStream input)
-        {
-            uint tag;
-            while ((tag = input.ReadTag()) != 0)
-            {
-                switch (tag)
-                {
-                    default:
-                        input.SkipLastField();
-                        break;
-                    case 9:
-                        {
-                            Latitude = input.ReadDouble();
-                            break;
-                        }
-                    case 17:
-                        {
-                            Longitude = input.ReadDouble();
-                            break;
-                        }
-                }
-            }
-        }
-
-        public override bool Equals(object other)
-        {
-            return Equals(other as PlayerUpdateRequest);
-        }
-
-        public override int GetHashCode()
-        {
-            var hash = 1;
-            if (Latitude != 0D) hash ^= Latitude.GetHashCode();
-            if (Longitude != 0D) hash ^= Longitude.GetHashCode();
-            return hash;
-        }
-
-        partial void OnConstruction();
-
-        public override string ToString()
-        {
-            return pb::JsonFormatter.ToDiagnosticString(this);
-        }
-    }
-
-    [global::System.Diagnostics.DebuggerNonUserCodeAttribute()]
-    public sealed partial class PlayerUpdateResponse : pb::IMessage<PlayerUpdateResponse>
-    {
-        /// <summary>Field number for the "wild_pokemons" field.</summary>
-        public const int WildPokemonsFieldNumber = 1;
-
-        /// <summary>Field number for the "forts" field.</summary>
-        public const int FortsFieldNumber = 2;
-
-        /// <summary>Field number for the "forts_nearby" field.</summary>
-        public const int FortsNearbyFieldNumber = 3;
-
-        private static readonly pb::MessageParser<PlayerUpdateResponse> _parser =
-            new pb::MessageParser<PlayerUpdateResponse>(() => new PlayerUpdateResponse());
-
-        private static readonly pb::FieldCodec<global::PokemonGo.RocketAPI.GeneratedCode.WildPokemon>
-            _repeated_wildPokemons_codec
-                = pb::FieldCodec.ForMessage(10, global::PokemonGo.RocketAPI.GeneratedCode.WildPokemon.Parser);
-
-        private static readonly pb::FieldCodec<global::PokemonGo.RocketAPI.GeneratedCode.FortData> _repeated_forts_codec
-            = pb::FieldCodec.ForMessage(18, global::PokemonGo.RocketAPI.GeneratedCode.FortData.Parser);
-
-        private readonly pbc::RepeatedField<global::PokemonGo.RocketAPI.GeneratedCode.FortData> forts_ =
-            new pbc::RepeatedField<global::PokemonGo.RocketAPI.GeneratedCode.FortData>();
-
-        private readonly pbc::RepeatedField<global::PokemonGo.RocketAPI.GeneratedCode.WildPokemon> wildPokemons_ =
-            new pbc::RepeatedField<global::PokemonGo.RocketAPI.GeneratedCode.WildPokemon>();
-
-        private int fortsNearby_;
-
-        public PlayerUpdateResponse()
-        {
-            OnConstruction();
-        }
-
-        public PlayerUpdateResponse(PlayerUpdateResponse other) : this()
-        {
-            wildPokemons_ = other.wildPokemons_.Clone();
-            forts_ = other.forts_.Clone();
-            fortsNearby_ = other.fortsNearby_;
-        }
-
-        public static pb::MessageParser<PlayerUpdateResponse> Parser
-        {
-            get { return _parser; }
-        }
-
-        public static pbr::MessageDescriptor Descriptor
-        {
-            get { return global::PokemonGo.RocketAPI.GeneratedCode.PayloadsReflection.Descriptor.MessageTypes[42]; }
-        }
-
-        public pbc::RepeatedField<global::PokemonGo.RocketAPI.GeneratedCode.WildPokemon> WildPokemons
-        {
-            get { return wildPokemons_; }
-        }
-
-        public pbc::RepeatedField<global::PokemonGo.RocketAPI.GeneratedCode.FortData> Forts
-        {
-            get { return forts_; }
-        }
-
-        public int FortsNearby
-        {
-            get { return fortsNearby_; }
-            set { fortsNearby_ = value; }
-        }
-
-        pbr::MessageDescriptor pb::IMessage.Descriptor
-        {
-            get { return Descriptor; }
-        }
-
-        public PlayerUpdateResponse Clone()
-        {
-            return new PlayerUpdateResponse(this);
-        }
-
-        public bool Equals(PlayerUpdateResponse other)
-        {
-            if (ReferenceEquals(other, null))
-            {
-                return false;
-            }
-            if (ReferenceEquals(other, this))
-            {
-                return true;
-            }
-            if (!wildPokemons_.Equals(other.wildPokemons_)) return false;
-            if (!forts_.Equals(other.forts_)) return false;
-            if (FortsNearby != other.FortsNearby) return false;
-            return true;
-        }
-
-        public void WriteTo(pb::CodedOutputStream output)
-        {
-            wildPokemons_.WriteTo(output, _repeated_wildPokemons_codec);
-            forts_.WriteTo(output, _repeated_forts_codec);
-            if (FortsNearby != 0)
-            {
-                output.WriteRawTag(24);
-                output.WriteInt32(FortsNearby);
-            }
-        }
-
-        public int CalculateSize()
-        {
-            var size = 0;
-            size += wildPokemons_.CalculateSize(_repeated_wildPokemons_codec);
-            size += forts_.CalculateSize(_repeated_forts_codec);
-            if (FortsNearby != 0)
-            {
-                size += 1 + pb::CodedOutputStream.ComputeInt32Size(FortsNearby);
-            }
-            return size;
-        }
-
-        public void MergeFrom(PlayerUpdateResponse other)
-        {
-            if (other == null)
-            {
-                return;
-            }
-            wildPokemons_.Add(other.wildPokemons_);
-            forts_.Add(other.forts_);
-            if (other.FortsNearby != 0)
-            {
-                FortsNearby = other.FortsNearby;
-            }
-        }
-
-        public void MergeFrom(pb::CodedInputStream input)
-        {
-            uint tag;
-            while ((tag = input.ReadTag()) != 0)
-            {
-                switch (tag)
-                {
-                    default:
-                        input.SkipLastField();
-                        break;
-                    case 10:
-                        {
-                            wildPokemons_.AddEntriesFrom(input, _repeated_wildPokemons_codec);
-                            break;
-                        }
-                    case 18:
-                        {
-                            forts_.AddEntriesFrom(input, _repeated_forts_codec);
-                            break;
-                        }
-                    case 24:
-                        {
-                            FortsNearby = input.ReadInt32();
-                            break;
-                        }
-                }
-            }
-        }
-
-        public override bool Equals(object other)
-        {
-            return Equals(other as PlayerUpdateResponse);
-        }
-
-        public override int GetHashCode()
-        {
-            var hash = 1;
-            hash ^= wildPokemons_.GetHashCode();
-            hash ^= forts_.GetHashCode();
-            if (FortsNearby != 0) hash ^= FortsNearby.GetHashCode();
-            return hash;
-        }
-
-        partial void OnConstruction();
-
-        public override string ToString()
-        {
-            return pb::JsonFormatter.ToDiagnosticString(this);
-        }
-    }
-
-    /// <summary>
-    ///     No message needed.
-    /// </summary>
-    [global::System.Diagnostics.DebuggerNonUserCodeAttribute()]
-    public sealed partial class DownloadItemTemplatesRequest : pb::IMessage<DownloadItemTemplatesRequest>
-    {
-        private static readonly pb::MessageParser<DownloadItemTemplatesRequest> _parser =
-            new pb::MessageParser<DownloadItemTemplatesRequest>(() => new DownloadItemTemplatesRequest());
-
-        public DownloadItemTemplatesRequest()
-        {
-            OnConstruction();
-        }
-
-        public DownloadItemTemplatesRequest(DownloadItemTemplatesRequest other) : this()
-        {
-        }
-
-        public static pb::MessageParser<DownloadItemTemplatesRequest> Parser
-        {
-            get { return _parser; }
-        }
-
-        public static pbr::MessageDescriptor Descriptor
-        {
-            get { return global::PokemonGo.RocketAPI.GeneratedCode.PayloadsReflection.Descriptor.MessageTypes[43]; }
-        }
-
-        pbr::MessageDescriptor pb::IMessage.Descriptor
-        {
-            get { return Descriptor; }
-        }
-
-        public DownloadItemTemplatesRequest Clone()
-        {
-            return new DownloadItemTemplatesRequest(this);
-        }
-
-        public bool Equals(DownloadItemTemplatesRequest other)
-        {
-            if (ReferenceEquals(other, null))
-            {
-                return false;
-            }
-            if (ReferenceEquals(other, this))
-            {
-                return true;
-            }
-            return true;
-        }
-
-        public void WriteTo(pb::CodedOutputStream output)
-        {
-        }
-
-        public int CalculateSize()
-        {
-            var size = 0;
-            return size;
-        }
-
-        public void MergeFrom(DownloadItemTemplatesRequest other)
-        {
-            if (other == null)
-            {
-                return;
-            }
-        }
-
-        public void MergeFrom(pb::CodedInputStream input)
-        {
-            uint tag;
-            while ((tag = input.ReadTag()) != 0)
-            {
-                switch (tag)
-                {
-                    default:
-                        input.SkipLastField();
-                        break;
-                }
-            }
-        }
-
-        public override bool Equals(object other)
-        {
-            return Equals(other as DownloadItemTemplatesRequest);
-        }
-
-        public override int GetHashCode()
-        {
-            var hash = 1;
-            return hash;
-        }
-
-        partial void OnConstruction();
-
-        public override string ToString()
-        {
-            return pb::JsonFormatter.ToDiagnosticString(this);
-        }
-    }
-
-    [global::System.Diagnostics.DebuggerNonUserCodeAttribute()]
-    public sealed partial class DownloadItemTemplatesResponse : pb::IMessage<DownloadItemTemplatesResponse>
-    {
-        /// <summary>Field number for the "success" field.</summary>
-        public const int SuccessFieldNumber = 1;
-
-        /// <summary>Field number for the "item_templates" field.</summary>
-        public const int ItemTemplatesFieldNumber = 2;
-
-        /// <summary>Field number for the "timestamp_ms" field.</summary>
-        public const int TimestampMsFieldNumber = 3;
-
-        private static readonly pb::MessageParser<DownloadItemTemplatesResponse> _parser =
-            new pb::MessageParser<DownloadItemTemplatesResponse>(() => new DownloadItemTemplatesResponse());
-
-        private static readonly
-            pb::FieldCodec<global::PokemonGo.RocketAPI.GeneratedCode.DownloadItemTemplatesResponse.Types.ItemTemplate>
-            _repeated_itemTemplates_codec
-                = pb::FieldCodec.ForMessage(18,
-                    global::PokemonGo.RocketAPI.GeneratedCode.DownloadItemTemplatesResponse.Types.ItemTemplate.Parser);
-
-        private readonly
-            pbc::RepeatedField
-                <global::PokemonGo.RocketAPI.GeneratedCode.DownloadItemTemplatesResponse.Types.ItemTemplate>
-            itemTemplates_ =
-                new pbc::RepeatedField
-                    <global::PokemonGo.RocketAPI.GeneratedCode.DownloadItemTemplatesResponse.Types.ItemTemplate>();
-
-        private bool success_;
-        private ulong timestampMs_;
-
-        public DownloadItemTemplatesResponse()
-        {
-            OnConstruction();
-        }
-
-        public DownloadItemTemplatesResponse(DownloadItemTemplatesResponse other) : this()
-        {
-            success_ = other.success_;
-            itemTemplates_ = other.itemTemplates_.Clone();
-            timestampMs_ = other.timestampMs_;
-        }
-
-        public static pb::MessageParser<DownloadItemTemplatesResponse> Parser
-        {
-            get { return _parser; }
-        }
-
-        public static pbr::MessageDescriptor Descriptor
-        {
-            get { return global::PokemonGo.RocketAPI.GeneratedCode.PayloadsReflection.Descriptor.MessageTypes[44]; }
-        }
-
-        public bool Success
-        {
-            get { return success_; }
-            set { success_ = value; }
-        }
-
-        public
-            pbc::RepeatedField
-                <global::PokemonGo.RocketAPI.GeneratedCode.DownloadItemTemplatesResponse.Types.ItemTemplate>
-            ItemTemplates
-        {
-            get { return itemTemplates_; }
-        }
-
-        public ulong TimestampMs
-        {
-            get { return timestampMs_; }
-            set { timestampMs_ = value; }
-        }
-
-        pbr::MessageDescriptor pb::IMessage.Descriptor
-        {
-            get { return Descriptor; }
-        }
-
-        public DownloadItemTemplatesResponse Clone()
-        {
-            return new DownloadItemTemplatesResponse(this);
-        }
-
-        public bool Equals(DownloadItemTemplatesResponse other)
-        {
-            if (ReferenceEquals(other, null))
-            {
-                return false;
-            }
-            if (ReferenceEquals(other, this))
-            {
-                return true;
-            }
-            if (Success != other.Success) return false;
-            if (!itemTemplates_.Equals(other.itemTemplates_)) return false;
-            if (TimestampMs != other.TimestampMs) return false;
-            return true;
-        }
-
-        public void WriteTo(pb::CodedOutputStream output)
-        {
-            if (Success != false)
-            {
-                output.WriteRawTag(8);
-                output.WriteBool(Success);
-            }
-            itemTemplates_.WriteTo(output, _repeated_itemTemplates_codec);
-            if (TimestampMs != 0UL)
-            {
-                output.WriteRawTag(24);
-                output.WriteUInt64(TimestampMs);
-            }
-        }
-
-        public int CalculateSize()
-        {
-            var size = 0;
-            if (Success != false)
-            {
-                size += 1 + 1;
-            }
-            size += itemTemplates_.CalculateSize(_repeated_itemTemplates_codec);
-            if (TimestampMs != 0UL)
-            {
-                size += 1 + pb::CodedOutputStream.ComputeUInt64Size(TimestampMs);
-            }
-            return size;
-        }
-
-        public void MergeFrom(DownloadItemTemplatesResponse other)
-        {
-            if (other == null)
-            {
-                return;
-            }
-            if (other.Success != false)
-            {
-                Success = other.Success;
-            }
-            itemTemplates_.Add(other.itemTemplates_);
-            if (other.TimestampMs != 0UL)
-            {
-                TimestampMs = other.TimestampMs;
-            }
-        }
-
-        public void MergeFrom(pb::CodedInputStream input)
-        {
-            uint tag;
-            while ((tag = input.ReadTag()) != 0)
-            {
-                switch (tag)
-                {
-                    default:
-                        input.SkipLastField();
-                        break;
-                    case 8:
-                        {
-                            Success = input.ReadBool();
-                            break;
-                        }
-                    case 18:
-                        {
-                            itemTemplates_.AddEntriesFrom(input, _repeated_itemTemplates_codec);
-                            break;
-                        }
-                    case 24:
-                        {
-                            TimestampMs = input.ReadUInt64();
-                            break;
-                        }
-                }
-            }
-        }
-
-        public override bool Equals(object other)
-        {
-            return Equals(other as DownloadItemTemplatesResponse);
-        }
-
-        public override int GetHashCode()
-        {
-            var hash = 1;
-            if (Success != false) hash ^= Success.GetHashCode();
-            hash ^= itemTemplates_.GetHashCode();
-            if (TimestampMs != 0UL) hash ^= TimestampMs.GetHashCode();
-            return hash;
-        }
-
-        partial void OnConstruction();
-
-        public override string ToString()
-        {
-            return pb::JsonFormatter.ToDiagnosticString(this);
-        }
-
-        #region Nested types
-
-        /// <summary>Container for nested types declared in the DownloadItemTemplatesResponse message type.</summary>
-        [global::System.Diagnostics.DebuggerNonUserCodeAttribute()]
-        public static partial class Types
-        {
-            [global::System.Diagnostics.DebuggerNonUserCodeAttribute()]
-            public sealed partial class ItemTemplate : pb::IMessage<ItemTemplate>
-            {
-                /// <summary>Field number for the "template_id" field.</summary>
-                public const int TemplateIdFieldNumber = 1;
-
-                /// <summary>Field number for the "pokemon_settings" field.</summary>
-                public const int PokemonSettingsFieldNumber = 2;
-
-                /// <summary>Field number for the "item_settings" field.</summary>
-                public const int ItemSettingsFieldNumber = 3;
-
-                /// <summary>Field number for the "move_settings" field.</summary>
-                public const int MoveSettingsFieldNumber = 4;
-
-                /// <summary>Field number for the "move_sequence_settings" field.</summary>
-                public const int MoveSequenceSettingsFieldNumber = 5;
-
-                /// <summary>Field number for the "type_effective" field.</summary>
-                public const int TypeEffectiveFieldNumber = 8;
-
-                /// <summary>Field number for the "badge_settings" field.</summary>
-                public const int BadgeSettingsFieldNumber = 10;
-
-                /// <summary>Field number for the "camera" field.</summary>
-                public const int CameraFieldNumber = 11;
-
-                /// <summary>Field number for the "player_level" field.</summary>
-                public const int PlayerLevelFieldNumber = 12;
-
-                /// <summary>Field number for the "gym_level" field.</summary>
-                public const int GymLevelFieldNumber = 13;
-
-                /// <summary>Field number for the "battle_settings" field.</summary>
-                public const int BattleSettingsFieldNumber = 14;
-
-                /// <summary>Field number for the "encounter_settings" field.</summary>
-                public const int EncounterSettingsFieldNumber = 15;
-
-                /// <summary>Field number for the "iap_item_display" field.</summary>
-                public const int IapItemDisplayFieldNumber = 16;
-
-                /// <summary>Field number for the "iap_settings" field.</summary>
-                public const int IapSettingsFieldNumber = 17;
-
-                /// <summary>Field number for the "pokemon_upgrades" field.</summary>
-                public const int PokemonUpgradesFieldNumber = 18;
-
-                /// <summary>Field number for the "equipped_badges" field.</summary>
-                public const int EquippedBadgesFieldNumber = 19;
-
-                private static readonly pb::MessageParser<ItemTemplate> _parser =
-                    new pb::MessageParser<ItemTemplate>(() => new ItemTemplate());
-
-                private global::PokemonGo.RocketAPI.GeneratedCode.BadgeSettings badgeSettings_;
-                private global::PokemonGo.RocketAPI.GeneratedCode.GymBattleSettings battleSettings_;
-                private global::PokemonGo.RocketAPI.GeneratedCode.CameraSettings camera_;
-                private global::PokemonGo.RocketAPI.GeneratedCode.EncounterSettings encounterSettings_;
-                private global::PokemonGo.RocketAPI.GeneratedCode.EquippedBadgeSettings equippedBadges_;
-                private global::PokemonGo.RocketAPI.GeneratedCode.GymLevelSettings gymLevel_;
-                private global::PokemonGo.RocketAPI.GeneratedCode.IapItemDisplay iapItemDisplay_;
-                private global::PokemonGo.RocketAPI.GeneratedCode.IapSettings iapSettings_;
-                private global::PokemonGo.RocketAPI.GeneratedCode.ItemSettings itemSettings_;
-                private global::PokemonGo.RocketAPI.GeneratedCode.MoveSequenceSettings moveSequenceSettings_;
-                private global::PokemonGo.RocketAPI.GeneratedCode.MoveSettings moveSettings_;
-                private global::PokemonGo.RocketAPI.GeneratedCode.PlayerLevelSettings playerLevel_;
-                private global::PokemonGo.RocketAPI.GeneratedCode.PokemonSettings pokemonSettings_;
-                private global::PokemonGo.RocketAPI.GeneratedCode.PokemonUpgradeSettings pokemonUpgrades_;
-                private string templateId_ = "";
-                private global::PokemonGo.RocketAPI.GeneratedCode.TypeEffectiveSettings typeEffective_;
-
-                public ItemTemplate()
-                {
-                    OnConstruction();
-                }
-
-                public ItemTemplate(ItemTemplate other) : this()
-                {
-                    templateId_ = other.templateId_;
-                    PokemonSettings = other.pokemonSettings_ != null ? other.PokemonSettings.Clone() : null;
-                    ItemSettings = other.itemSettings_ != null ? other.ItemSettings.Clone() : null;
-                    MoveSettings = other.moveSettings_ != null ? other.MoveSettings.Clone() : null;
-                    MoveSequenceSettings = other.moveSequenceSettings_ != null
-                        ? other.MoveSequenceSettings.Clone()
-                        : null;
-                    TypeEffective = other.typeEffective_ != null ? other.TypeEffective.Clone() : null;
-                    BadgeSettings = other.badgeSettings_ != null ? other.BadgeSettings.Clone() : null;
-                    Camera = other.camera_ != null ? other.Camera.Clone() : null;
-                    PlayerLevel = other.playerLevel_ != null ? other.PlayerLevel.Clone() : null;
-                    GymLevel = other.gymLevel_ != null ? other.GymLevel.Clone() : null;
-                    BattleSettings = other.battleSettings_ != null ? other.BattleSettings.Clone() : null;
-                    EncounterSettings = other.encounterSettings_ != null ? other.EncounterSettings.Clone() : null;
-                    IapItemDisplay = other.iapItemDisplay_ != null ? other.IapItemDisplay.Clone() : null;
-                    IapSettings = other.iapSettings_ != null ? other.IapSettings.Clone() : null;
-                    PokemonUpgrades = other.pokemonUpgrades_ != null ? other.PokemonUpgrades.Clone() : null;
-                    EquippedBadges = other.equippedBadges_ != null ? other.EquippedBadges.Clone() : null;
-                }
-
-                public static pb::MessageParser<ItemTemplate> Parser
-                {
-                    get { return _parser; }
-                }
-
-                public static pbr::MessageDescriptor Descriptor
-                {
-                    get
-                    {
-                        return
-                            global::PokemonGo.RocketAPI.GeneratedCode.DownloadItemTemplatesResponse.Descriptor
-                                .NestedTypes[0];
-                    }
-                }
-
-                public string TemplateId
-                {
-                    get { return templateId_; }
-                    set { templateId_ = pb::ProtoPreconditions.CheckNotNull(value, "value"); }
-                }
-
-                public global::PokemonGo.RocketAPI.GeneratedCode.PokemonSettings PokemonSettings
-                {
-                    get { return pokemonSettings_; }
-                    set { pokemonSettings_ = value; }
-                }
-
-                public global::PokemonGo.RocketAPI.GeneratedCode.ItemSettings ItemSettings
-                {
-                    get { return itemSettings_; }
-                    set { itemSettings_ = value; }
-                }
-
-                public global::PokemonGo.RocketAPI.GeneratedCode.MoveSettings MoveSettings
-                {
-                    get { return moveSettings_; }
-                    set { moveSettings_ = value; }
-                }
-
-                public global::PokemonGo.RocketAPI.GeneratedCode.MoveSequenceSettings MoveSequenceSettings
-                {
-                    get { return moveSequenceSettings_; }
-                    set { moveSequenceSettings_ = value; }
-                }
-
-                public global::PokemonGo.RocketAPI.GeneratedCode.TypeEffectiveSettings TypeEffective
-                {
-                    get { return typeEffective_; }
-                    set { typeEffective_ = value; }
-                }
-
-                public global::PokemonGo.RocketAPI.GeneratedCode.BadgeSettings BadgeSettings
-                {
-                    get { return badgeSettings_; }
-                    set { badgeSettings_ = value; }
-                }
-
-                public global::PokemonGo.RocketAPI.GeneratedCode.CameraSettings Camera
-                {
-                    get { return camera_; }
-                    set { camera_ = value; }
-                }
-
-                public global::PokemonGo.RocketAPI.GeneratedCode.PlayerLevelSettings PlayerLevel
-                {
-                    get { return playerLevel_; }
-                    set { playerLevel_ = value; }
-                }
-
-                public global::PokemonGo.RocketAPI.GeneratedCode.GymLevelSettings GymLevel
-                {
-                    get { return gymLevel_; }
-                    set { gymLevel_ = value; }
-                }
-
-                public global::PokemonGo.RocketAPI.GeneratedCode.GymBattleSettings BattleSettings
-                {
-                    get { return battleSettings_; }
-                    set { battleSettings_ = value; }
-                }
-
-                public global::PokemonGo.RocketAPI.GeneratedCode.EncounterSettings EncounterSettings
-                {
-                    get { return encounterSettings_; }
-                    set { encounterSettings_ = value; }
-                }
-
-                public global::PokemonGo.RocketAPI.GeneratedCode.IapItemDisplay IapItemDisplay
-                {
-                    get { return iapItemDisplay_; }
-                    set { iapItemDisplay_ = value; }
-                }
-
-                public global::PokemonGo.RocketAPI.GeneratedCode.IapSettings IapSettings
-                {
-                    get { return iapSettings_; }
-                    set { iapSettings_ = value; }
-                }
-
-                public global::PokemonGo.RocketAPI.GeneratedCode.PokemonUpgradeSettings PokemonUpgrades
-                {
-                    get { return pokemonUpgrades_; }
-                    set { pokemonUpgrades_ = value; }
-                }
-
-                public global::PokemonGo.RocketAPI.GeneratedCode.EquippedBadgeSettings EquippedBadges
-                {
-                    get { return equippedBadges_; }
-                    set { equippedBadges_ = value; }
-                }
-
-                pbr::MessageDescriptor pb::IMessage.Descriptor
-                {
-                    get { return Descriptor; }
-                }
-
-                public ItemTemplate Clone()
-                {
-                    return new ItemTemplate(this);
-                }
-
-                public bool Equals(ItemTemplate other)
-                {
-                    if (ReferenceEquals(other, null))
-                    {
-                        return false;
-                    }
-                    if (ReferenceEquals(other, this))
-                    {
-                        return true;
-                    }
-                    if (TemplateId != other.TemplateId) return false;
-                    if (!Equals(PokemonSettings, other.PokemonSettings)) return false;
-                    if (!Equals(ItemSettings, other.ItemSettings)) return false;
-                    if (!Equals(MoveSettings, other.MoveSettings)) return false;
-                    if (!Equals(MoveSequenceSettings, other.MoveSequenceSettings)) return false;
-                    if (!Equals(TypeEffective, other.TypeEffective)) return false;
-                    if (!Equals(BadgeSettings, other.BadgeSettings)) return false;
-                    if (!Equals(Camera, other.Camera)) return false;
-                    if (!Equals(PlayerLevel, other.PlayerLevel)) return false;
-                    if (!Equals(GymLevel, other.GymLevel)) return false;
-                    if (!Equals(BattleSettings, other.BattleSettings)) return false;
-                    if (!Equals(EncounterSettings, other.EncounterSettings)) return false;
-                    if (!Equals(IapItemDisplay, other.IapItemDisplay)) return false;
-                    if (!Equals(IapSettings, other.IapSettings)) return false;
-                    if (!Equals(PokemonUpgrades, other.PokemonUpgrades)) return false;
-                    if (!Equals(EquippedBadges, other.EquippedBadges)) return false;
-                    return true;
-                }
-
-                public void WriteTo(pb::CodedOutputStream output)
-                {
-                    if (TemplateId.Length != 0)
-                    {
-                        output.WriteRawTag(10);
-                        output.WriteString(TemplateId);
-                    }
-                    if (pokemonSettings_ != null)
-                    {
-                        output.WriteRawTag(18);
-                        output.WriteMessage(PokemonSettings);
-                    }
-                    if (itemSettings_ != null)
-                    {
-                        output.WriteRawTag(26);
-                        output.WriteMessage(ItemSettings);
-                    }
-                    if (moveSettings_ != null)
-                    {
-                        output.WriteRawTag(34);
-                        output.WriteMessage(MoveSettings);
-                    }
-                    if (moveSequenceSettings_ != null)
-                    {
-                        output.WriteRawTag(42);
-                        output.WriteMessage(MoveSequenceSettings);
-                    }
-                    if (typeEffective_ != null)
-                    {
-                        output.WriteRawTag(66);
-                        output.WriteMessage(TypeEffective);
-                    }
-                    if (badgeSettings_ != null)
-                    {
-                        output.WriteRawTag(82);
-                        output.WriteMessage(BadgeSettings);
-                    }
-                    if (camera_ != null)
-                    {
-                        output.WriteRawTag(90);
-                        output.WriteMessage(Camera);
-                    }
-                    if (playerLevel_ != null)
-                    {
-                        output.WriteRawTag(98);
-                        output.WriteMessage(PlayerLevel);
-                    }
-                    if (gymLevel_ != null)
-                    {
-                        output.WriteRawTag(106);
-                        output.WriteMessage(GymLevel);
-                    }
-                    if (battleSettings_ != null)
-                    {
-                        output.WriteRawTag(114);
-                        output.WriteMessage(BattleSettings);
-                    }
-                    if (encounterSettings_ != null)
-                    {
-                        output.WriteRawTag(122);
-                        output.WriteMessage(EncounterSettings);
-                    }
-                    if (iapItemDisplay_ != null)
-                    {
-                        output.WriteRawTag(130, 1);
-                        output.WriteMessage(IapItemDisplay);
-                    }
-                    if (iapSettings_ != null)
-                    {
-                        output.WriteRawTag(138, 1);
-                        output.WriteMessage(IapSettings);
-                    }
-                    if (pokemonUpgrades_ != null)
-                    {
-                        output.WriteRawTag(146, 1);
-                        output.WriteMessage(PokemonUpgrades);
-                    }
-                    if (equippedBadges_ != null)
-                    {
-                        output.WriteRawTag(154, 1);
-                        output.WriteMessage(EquippedBadges);
-                    }
-                }
-
-                public int CalculateSize()
-                {
-                    var size = 0;
-                    if (TemplateId.Length != 0)
-                    {
-                        size += 1 + pb::CodedOutputStream.ComputeStringSize(TemplateId);
-                    }
-                    if (pokemonSettings_ != null)
-                    {
-                        size += 1 + pb::CodedOutputStream.ComputeMessageSize(PokemonSettings);
-                    }
-                    if (itemSettings_ != null)
-                    {
-                        size += 1 + pb::CodedOutputStream.ComputeMessageSize(ItemSettings);
-                    }
-                    if (moveSettings_ != null)
-                    {
-                        size += 1 + pb::CodedOutputStream.ComputeMessageSize(MoveSettings);
-                    }
-                    if (moveSequenceSettings_ != null)
-                    {
-                        size += 1 + pb::CodedOutputStream.ComputeMessageSize(MoveSequenceSettings);
-                    }
-                    if (typeEffective_ != null)
-                    {
-                        size += 1 + pb::CodedOutputStream.ComputeMessageSize(TypeEffective);
-                    }
-                    if (badgeSettings_ != null)
-                    {
-                        size += 1 + pb::CodedOutputStream.ComputeMessageSize(BadgeSettings);
-                    }
-                    if (camera_ != null)
-                    {
-                        size += 1 + pb::CodedOutputStream.ComputeMessageSize(Camera);
-                    }
-                    if (playerLevel_ != null)
-                    {
-                        size += 1 + pb::CodedOutputStream.ComputeMessageSize(PlayerLevel);
-                    }
-                    if (gymLevel_ != null)
-                    {
-                        size += 1 + pb::CodedOutputStream.ComputeMessageSize(GymLevel);
-                    }
-                    if (battleSettings_ != null)
-                    {
-                        size += 1 + pb::CodedOutputStream.ComputeMessageSize(BattleSettings);
-                    }
-                    if (encounterSettings_ != null)
-                    {
-                        size += 1 + pb::CodedOutputStream.ComputeMessageSize(EncounterSettings);
-                    }
-                    if (iapItemDisplay_ != null)
-                    {
-                        size += 2 + pb::CodedOutputStream.ComputeMessageSize(IapItemDisplay);
-                    }
-                    if (iapSettings_ != null)
-                    {
-                        size += 2 + pb::CodedOutputStream.ComputeMessageSize(IapSettings);
-                    }
-                    if (pokemonUpgrades_ != null)
-                    {
-                        size += 2 + pb::CodedOutputStream.ComputeMessageSize(PokemonUpgrades);
-                    }
-                    if (equippedBadges_ != null)
-                    {
-                        size += 2 + pb::CodedOutputStream.ComputeMessageSize(EquippedBadges);
-                    }
-                    return size;
-                }
-
-                public void MergeFrom(ItemTemplate other)
-                {
-                    if (other == null)
-                    {
-                        return;
-                    }
-                    if (other.TemplateId.Length != 0)
-                    {
-                        TemplateId = other.TemplateId;
-                    }
-                    if (other.pokemonSettings_ != null)
-                    {
-                        if (pokemonSettings_ == null)
-                        {
-                            pokemonSettings_ = new global::PokemonGo.RocketAPI.GeneratedCode.PokemonSettings();
-                        }
-                        PokemonSettings.MergeFrom(other.PokemonSettings);
-                    }
-                    if (other.itemSettings_ != null)
-                    {
-                        if (itemSettings_ == null)
-                        {
-                            itemSettings_ = new global::PokemonGo.RocketAPI.GeneratedCode.ItemSettings();
-                        }
-                        ItemSettings.MergeFrom(other.ItemSettings);
-                    }
-                    if (other.moveSettings_ != null)
-                    {
-                        if (moveSettings_ == null)
-                        {
-                            moveSettings_ = new global::PokemonGo.RocketAPI.GeneratedCode.MoveSettings();
-                        }
-                        MoveSettings.MergeFrom(other.MoveSettings);
-                    }
-                    if (other.moveSequenceSettings_ != null)
-                    {
-                        if (moveSequenceSettings_ == null)
-                        {
-                            moveSequenceSettings_ = new global::PokemonGo.RocketAPI.GeneratedCode.MoveSequenceSettings();
-                        }
-                        MoveSequenceSettings.MergeFrom(other.MoveSequenceSettings);
-                    }
-                    if (other.typeEffective_ != null)
-                    {
-                        if (typeEffective_ == null)
-                        {
-                            typeEffective_ = new global::PokemonGo.RocketAPI.GeneratedCode.TypeEffectiveSettings();
-                        }
-                        TypeEffective.MergeFrom(other.TypeEffective);
-                    }
-                    if (other.badgeSettings_ != null)
-                    {
-                        if (badgeSettings_ == null)
-                        {
-                            badgeSettings_ = new global::PokemonGo.RocketAPI.GeneratedCode.BadgeSettings();
-                        }
-                        BadgeSettings.MergeFrom(other.BadgeSettings);
-                    }
-                    if (other.camera_ != null)
-                    {
-                        if (camera_ == null)
-                        {
-                            camera_ = new global::PokemonGo.RocketAPI.GeneratedCode.CameraSettings();
-                        }
-                        Camera.MergeFrom(other.Camera);
-                    }
-                    if (other.playerLevel_ != null)
-                    {
-                        if (playerLevel_ == null)
-                        {
-                            playerLevel_ = new global::PokemonGo.RocketAPI.GeneratedCode.PlayerLevelSettings();
-                        }
-                        PlayerLevel.MergeFrom(other.PlayerLevel);
-                    }
-                    if (other.gymLevel_ != null)
-                    {
-                        if (gymLevel_ == null)
-                        {
-                            gymLevel_ = new global::PokemonGo.RocketAPI.GeneratedCode.GymLevelSettings();
-                        }
-                        GymLevel.MergeFrom(other.GymLevel);
-                    }
-                    if (other.battleSettings_ != null)
-                    {
-                        if (battleSettings_ == null)
-                        {
-                            battleSettings_ = new global::PokemonGo.RocketAPI.GeneratedCode.GymBattleSettings();
-                        }
-                        BattleSettings.MergeFrom(other.BattleSettings);
-                    }
-                    if (other.encounterSettings_ != null)
-                    {
-                        if (encounterSettings_ == null)
-                        {
-                            encounterSettings_ = new global::PokemonGo.RocketAPI.GeneratedCode.EncounterSettings();
-                        }
-                        EncounterSettings.MergeFrom(other.EncounterSettings);
-                    }
-                    if (other.iapItemDisplay_ != null)
-                    {
-                        if (iapItemDisplay_ == null)
-                        {
-                            iapItemDisplay_ = new global::PokemonGo.RocketAPI.GeneratedCode.IapItemDisplay();
-                        }
-                        IapItemDisplay.MergeFrom(other.IapItemDisplay);
-                    }
-                    if (other.iapSettings_ != null)
-                    {
-                        if (iapSettings_ == null)
-                        {
-                            iapSettings_ = new global::PokemonGo.RocketAPI.GeneratedCode.IapSettings();
-                        }
-                        IapSettings.MergeFrom(other.IapSettings);
-                    }
-                    if (other.pokemonUpgrades_ != null)
-                    {
-                        if (pokemonUpgrades_ == null)
-                        {
-                            pokemonUpgrades_ = new global::PokemonGo.RocketAPI.GeneratedCode.PokemonUpgradeSettings();
-                        }
-                        PokemonUpgrades.MergeFrom(other.PokemonUpgrades);
-                    }
-                    if (other.equippedBadges_ != null)
-                    {
-                        if (equippedBadges_ == null)
-                        {
-                            equippedBadges_ = new global::PokemonGo.RocketAPI.GeneratedCode.EquippedBadgeSettings();
-                        }
-                        EquippedBadges.MergeFrom(other.EquippedBadges);
-                    }
-                }
-
-                public void MergeFrom(pb::CodedInputStream input)
-                {
-                    uint tag;
-                    while ((tag = input.ReadTag()) != 0)
-                    {
-                        switch (tag)
-                        {
-                            default:
-                                input.SkipLastField();
-                                break;
-                            case 10:
-                                {
-                                    TemplateId = input.ReadString();
-                                    break;
-                                }
-                            case 18:
-                                {
-                                    if (pokemonSettings_ == null)
-                                    {
-                                        pokemonSettings_ = new global::PokemonGo.RocketAPI.GeneratedCode.PokemonSettings();
-                                    }
-                                    input.ReadMessage(pokemonSettings_);
-                                    break;
-                                }
-                            case 26:
-                                {
-                                    if (itemSettings_ == null)
-                                    {
-                                        itemSettings_ = new global::PokemonGo.RocketAPI.GeneratedCode.ItemSettings();
-                                    }
-                                    input.ReadMessage(itemSettings_);
-                                    break;
-                                }
-                            case 34:
-                                {
-                                    if (moveSettings_ == null)
-                                    {
-                                        moveSettings_ = new global::PokemonGo.RocketAPI.GeneratedCode.MoveSettings();
-                                    }
-                                    input.ReadMessage(moveSettings_);
-                                    break;
-                                }
-                            case 42:
-                                {
-                                    if (moveSequenceSettings_ == null)
-                                    {
-                                        moveSequenceSettings_ =
-                                            new global::PokemonGo.RocketAPI.GeneratedCode.MoveSequenceSettings();
-                                    }
-                                    input.ReadMessage(moveSequenceSettings_);
-                                    break;
-                                }
-                            case 66:
-                                {
-                                    if (typeEffective_ == null)
-                                    {
-                                        typeEffective_ =
-                                            new global::PokemonGo.RocketAPI.GeneratedCode.TypeEffectiveSettings();
-                                    }
-                                    input.ReadMessage(typeEffective_);
-                                    break;
-                                }
-                            case 82:
-                                {
-                                    if (badgeSettings_ == null)
-                                    {
-                                        badgeSettings_ = new global::PokemonGo.RocketAPI.GeneratedCode.BadgeSettings();
-                                    }
-                                    input.ReadMessage(badgeSettings_);
-                                    break;
-                                }
-                            case 90:
-                                {
-                                    if (camera_ == null)
-                                    {
-                                        camera_ = new global::PokemonGo.RocketAPI.GeneratedCode.CameraSettings();
-                                    }
-                                    input.ReadMessage(camera_);
-                                    break;
-                                }
-                            case 98:
-                                {
-                                    if (playerLevel_ == null)
-                                    {
-                                        playerLevel_ = new global::PokemonGo.RocketAPI.GeneratedCode.PlayerLevelSettings();
-                                    }
-                                    input.ReadMessage(playerLevel_);
-                                    break;
-                                }
-                            case 106:
-                                {
-                                    if (gymLevel_ == null)
-                                    {
-                                        gymLevel_ = new global::PokemonGo.RocketAPI.GeneratedCode.GymLevelSettings();
-                                    }
-                                    input.ReadMessage(gymLevel_);
-                                    break;
-                                }
-                            case 114:
-                                {
-                                    if (battleSettings_ == null)
-                                    {
-                                        battleSettings_ = new global::PokemonGo.RocketAPI.GeneratedCode.GymBattleSettings();
-                                    }
-                                    input.ReadMessage(battleSettings_);
-                                    break;
-                                }
-                            case 122:
-                                {
-                                    if (encounterSettings_ == null)
-                                    {
-                                        encounterSettings_ =
-                                            new global::PokemonGo.RocketAPI.GeneratedCode.EncounterSettings();
-                                    }
-                                    input.ReadMessage(encounterSettings_);
-                                    break;
-                                }
-                            case 130:
-                                {
-                                    if (iapItemDisplay_ == null)
-                                    {
-                                        iapItemDisplay_ = new global::PokemonGo.RocketAPI.GeneratedCode.IapItemDisplay();
-                                    }
-                                    input.ReadMessage(iapItemDisplay_);
-                                    break;
-                                }
-                            case 138:
-                                {
-                                    if (iapSettings_ == null)
-                                    {
-                                        iapSettings_ = new global::PokemonGo.RocketAPI.GeneratedCode.IapSettings();
-                                    }
-                                    input.ReadMessage(iapSettings_);
-                                    break;
-                                }
-                            case 146:
-                                {
-                                    if (pokemonUpgrades_ == null)
-                                    {
-                                        pokemonUpgrades_ =
-                                            new global::PokemonGo.RocketAPI.GeneratedCode.PokemonUpgradeSettings();
-                                    }
-                                    input.ReadMessage(pokemonUpgrades_);
-                                    break;
-                                }
-                            case 154:
-                                {
-                                    if (equippedBadges_ == null)
-                                    {
-                                        equippedBadges_ =
-                                            new global::PokemonGo.RocketAPI.GeneratedCode.EquippedBadgeSettings();
-                                    }
-                                    input.ReadMessage(equippedBadges_);
-                                    break;
-                                }
-                        }
-                    }
-                }
-
-                public override bool Equals(object other)
-                {
-                    return Equals(other as ItemTemplate);
-                }
-
-                public override int GetHashCode()
-                {
-                    var hash = 1;
-                    if (TemplateId.Length != 0) hash ^= TemplateId.GetHashCode();
-                    if (pokemonSettings_ != null) hash ^= PokemonSettings.GetHashCode();
-                    if (itemSettings_ != null) hash ^= ItemSettings.GetHashCode();
-                    if (moveSettings_ != null) hash ^= MoveSettings.GetHashCode();
-                    if (moveSequenceSettings_ != null) hash ^= MoveSequenceSettings.GetHashCode();
-                    if (typeEffective_ != null) hash ^= TypeEffective.GetHashCode();
-                    if (badgeSettings_ != null) hash ^= BadgeSettings.GetHashCode();
-                    if (camera_ != null) hash ^= Camera.GetHashCode();
-                    if (playerLevel_ != null) hash ^= PlayerLevel.GetHashCode();
-                    if (gymLevel_ != null) hash ^= GymLevel.GetHashCode();
-                    if (battleSettings_ != null) hash ^= BattleSettings.GetHashCode();
-                    if (encounterSettings_ != null) hash ^= EncounterSettings.GetHashCode();
-                    if (iapItemDisplay_ != null) hash ^= IapItemDisplay.GetHashCode();
-                    if (iapSettings_ != null) hash ^= IapSettings.GetHashCode();
-                    if (pokemonUpgrades_ != null) hash ^= PokemonUpgrades.GetHashCode();
-                    if (equippedBadges_ != null) hash ^= EquippedBadges.GetHashCode();
-                    return hash;
-                }
-
-                partial void OnConstruction();
-
-                public override string ToString()
-                {
-                    return pb::JsonFormatter.ToDiagnosticString(this);
-                }
-            }
-        }
-
-        #endregion
-    }
-
-    [global::System.Diagnostics.DebuggerNonUserCodeAttribute()]
-    public sealed partial class UseItemCaptureRequest : pb::IMessage<UseItemCaptureRequest>
-    {
-        /// <summary>Field number for the "item_id" field.</summary>
-        public const int ItemIdFieldNumber = 1;
-
-        /// <summary>Field number for the "encounter_id" field.</summary>
-        public const int EncounterIdFieldNumber = 2;
-
-        /// <summary>Field number for the "spawn_point_guid" field.</summary>
-        public const int SpawnPointGuidFieldNumber = 3;
-
-        private static readonly pb::MessageParser<UseItemCaptureRequest> _parser =
-            new pb::MessageParser<UseItemCaptureRequest>(() => new UseItemCaptureRequest());
-
-        private ulong encounterId_;
-        private global::PokemonGo.RocketAPI.GeneratedCode.ItemId itemId_ = 0;
-        private string spawnPointGuid_ = "";
-
-        public UseItemCaptureRequest()
-        {
-            OnConstruction();
-        }
-
-        public UseItemCaptureRequest(UseItemCaptureRequest other) : this()
-        {
-            itemId_ = other.itemId_;
-            encounterId_ = other.encounterId_;
-            spawnPointGuid_ = other.spawnPointGuid_;
-        }
-
-        public static pb::MessageParser<UseItemCaptureRequest> Parser
-        {
-            get { return _parser; }
-        }
-
-        public static pbr::MessageDescriptor Descriptor
-        {
-            get { return global::PokemonGo.RocketAPI.GeneratedCode.PayloadsReflection.Descriptor.MessageTypes[45]; }
-        }
-
-        public global::PokemonGo.RocketAPI.GeneratedCode.ItemId ItemId
-        {
-            get { return itemId_; }
-            set { itemId_ = value; }
-        }
-
-        public ulong EncounterId
-        {
-            get { return encounterId_; }
-            set { encounterId_ = value; }
-        }
-
-        public string SpawnPointGuid
-        {
-            get { return spawnPointGuid_; }
-            set { spawnPointGuid_ = pb::ProtoPreconditions.CheckNotNull(value, "value"); }
-        }
-
-        pbr::MessageDescriptor pb::IMessage.Descriptor
-        {
-            get { return Descriptor; }
-        }
-
-        public UseItemCaptureRequest Clone()
-        {
-            return new UseItemCaptureRequest(this);
-        }
-
-        public bool Equals(UseItemCaptureRequest other)
-        {
-            if (ReferenceEquals(other, null))
-            {
-                return false;
-            }
-            if (ReferenceEquals(other, this))
-            {
-                return true;
-            }
-            if (ItemId != other.ItemId) return false;
-            if (EncounterId != other.EncounterId) return false;
-            if (SpawnPointGuid != other.SpawnPointGuid) return false;
-            return true;
-        }
-
-        public void WriteTo(pb::CodedOutputStream output)
-        {
-            if (ItemId != 0)
-            {
-                output.WriteRawTag(8);
-                output.WriteEnum((int)ItemId);
-            }
-            if (EncounterId != 0UL)
-            {
-                output.WriteRawTag(17);
-                output.WriteFixed64(EncounterId);
-            }
-            if (SpawnPointGuid.Length != 0)
-            {
-                output.WriteRawTag(26);
-                output.WriteString(SpawnPointGuid);
-            }
-        }
-
-        public int CalculateSize()
-        {
-            var size = 0;
-            if (ItemId != 0)
-            {
-                size += 1 + pb::CodedOutputStream.ComputeEnumSize((int)ItemId);
-            }
-            if (EncounterId != 0UL)
-            {
-                size += 1 + 8;
-            }
-            if (SpawnPointGuid.Length != 0)
-            {
-                size += 1 + pb::CodedOutputStream.ComputeStringSize(SpawnPointGuid);
-            }
-            return size;
-        }
-
-        public void MergeFrom(UseItemCaptureRequest other)
-        {
-            if (other == null)
-            {
-                return;
-            }
-            if (other.ItemId != 0)
-            {
-                ItemId = other.ItemId;
-            }
-            if (other.EncounterId != 0UL)
-            {
-                EncounterId = other.EncounterId;
-            }
-            if (other.SpawnPointGuid.Length != 0)
-            {
-                SpawnPointGuid = other.SpawnPointGuid;
-            }
-        }
-
-        public void MergeFrom(pb::CodedInputStream input)
-        {
-            uint tag;
-            while ((tag = input.ReadTag()) != 0)
-            {
-                switch (tag)
-                {
-                    default:
-                        input.SkipLastField();
-                        break;
-                    case 8:
-                        {
-                            itemId_ = (global::PokemonGo.RocketAPI.GeneratedCode.ItemId)input.ReadEnum();
-                            break;
-                        }
-                    case 17:
-                        {
-                            EncounterId = input.ReadFixed64();
-                            break;
-                        }
-                    case 26:
-                        {
-                            SpawnPointGuid = input.ReadString();
-                            break;
-                        }
-                }
-            }
-        }
-
-        public override bool Equals(object other)
-        {
-            return Equals(other as UseItemCaptureRequest);
-        }
-
-        public override int GetHashCode()
-        {
-            var hash = 1;
-            if (ItemId != 0) hash ^= ItemId.GetHashCode();
-            if (EncounterId != 0UL) hash ^= EncounterId.GetHashCode();
-            if (SpawnPointGuid.Length != 0) hash ^= SpawnPointGuid.GetHashCode();
-            return hash;
-        }
-
-        partial void OnConstruction();
-
-        public override string ToString()
-        {
-            return pb::JsonFormatter.ToDiagnosticString(this);
-        }
-    }
-
-    [global::System.Diagnostics.DebuggerNonUserCodeAttribute()]
-    public sealed partial class UseItemCaptureResponse : pb::IMessage<UseItemCaptureResponse>
-    {
-        /// <summary>Field number for the "success" field.</summary>
-        public const int SuccessFieldNumber = 1;
-
-        /// <summary>Field number for the "item_capture_mult" field.</summary>
-        public const int ItemCaptureMultFieldNumber = 2;
-
-        /// <summary>Field number for the "item_flee_mult" field.</summary>
-        public const int ItemFleeMultFieldNumber = 3;
-
-        /// <summary>Field number for the "stop_movement" field.</summary>
-        public const int StopMovementFieldNumber = 4;
-
-        /// <summary>Field number for the "stop_attack" field.</summary>
-        public const int StopAttackFieldNumber = 5;
-
-        /// <summary>Field number for the "target_max" field.</summary>
-        public const int TargetMaxFieldNumber = 6;
-
-        /// <summary>Field number for the "target_slow" field.</summary>
-        public const int TargetSlowFieldNumber = 7;
-
-        private static readonly pb::MessageParser<UseItemCaptureResponse> _parser =
-            new pb::MessageParser<UseItemCaptureResponse>(() => new UseItemCaptureResponse());
-
-        private double itemCaptureMult_;
-        private double itemFleeMult_;
-        private bool stopAttack_;
-        private bool stopMovement_;
-        private bool success_;
-        private bool targetMax_;
-        private bool targetSlow_;
-
-        public UseItemCaptureResponse()
-        {
-            OnConstruction();
-        }
-
-        public UseItemCaptureResponse(UseItemCaptureResponse other) : this()
-        {
-            success_ = other.success_;
-            itemCaptureMult_ = other.itemCaptureMult_;
-            itemFleeMult_ = other.itemFleeMult_;
-            stopMovement_ = other.stopMovement_;
-            stopAttack_ = other.stopAttack_;
-            targetMax_ = other.targetMax_;
-            targetSlow_ = other.targetSlow_;
-        }
-
-        public static pb::MessageParser<UseItemCaptureResponse> Parser
-        {
-            get { return _parser; }
-        }
-
-        public static pbr::MessageDescriptor Descriptor
-        {
-            get { return global::PokemonGo.RocketAPI.GeneratedCode.PayloadsReflection.Descriptor.MessageTypes[46]; }
-        }
-
-        public bool Success
-        {
-            get { return success_; }
-            set { success_ = value; }
-        }
-
-        public double ItemCaptureMult
-        {
-            get { return itemCaptureMult_; }
-            set { itemCaptureMult_ = value; }
-        }
-
-        public double ItemFleeMult
-        {
-            get { return itemFleeMult_; }
-            set { itemFleeMult_ = value; }
-        }
-
-        public bool StopMovement
-        {
-            get { return stopMovement_; }
-            set { stopMovement_ = value; }
-        }
-
-        public bool StopAttack
-        {
-            get { return stopAttack_; }
-            set { stopAttack_ = value; }
-        }
-
-        public bool TargetMax
-        {
-            get { return targetMax_; }
-            set { targetMax_ = value; }
-        }
-
-        public bool TargetSlow
-        {
-            get { return targetSlow_; }
-            set { targetSlow_ = value; }
-        }
-
-        pbr::MessageDescriptor pb::IMessage.Descriptor
-        {
-            get { return Descriptor; }
-        }
-
-        public UseItemCaptureResponse Clone()
-        {
-            return new UseItemCaptureResponse(this);
-        }
-
-        public bool Equals(UseItemCaptureResponse other)
-        {
-            if (ReferenceEquals(other, null))
-            {
-                return false;
-            }
-            if (ReferenceEquals(other, this))
-            {
-                return true;
-            }
-            if (Success != other.Success) return false;
-            if (ItemCaptureMult != other.ItemCaptureMult) return false;
-            if (ItemFleeMult != other.ItemFleeMult) return false;
-            if (StopMovement != other.StopMovement) return false;
-            if (StopAttack != other.StopAttack) return false;
-            if (TargetMax != other.TargetMax) return false;
-            if (TargetSlow != other.TargetSlow) return false;
-            return true;
-        }
-
-        public void WriteTo(pb::CodedOutputStream output)
-        {
-            if (Success != false)
-            {
-                output.WriteRawTag(8);
-                output.WriteBool(Success);
-            }
-            if (ItemCaptureMult != 0D)
-            {
-                output.WriteRawTag(17);
-                output.WriteDouble(ItemCaptureMult);
-            }
-            if (ItemFleeMult != 0D)
-            {
-                output.WriteRawTag(25);
-                output.WriteDouble(ItemFleeMult);
-            }
-            if (StopMovement != false)
-            {
-                output.WriteRawTag(32);
-                output.WriteBool(StopMovement);
-            }
-            if (StopAttack != false)
-            {
-                output.WriteRawTag(40);
-                output.WriteBool(StopAttack);
-            }
-            if (TargetMax != false)
-            {
-                output.WriteRawTag(48);
-                output.WriteBool(TargetMax);
-            }
-            if (TargetSlow != false)
-            {
-                output.WriteRawTag(56);
-                output.WriteBool(TargetSlow);
-            }
-        }
-
-        public int CalculateSize()
-        {
-            var size = 0;
-            if (Success != false)
-            {
-                size += 1 + 1;
-            }
-            if (ItemCaptureMult != 0D)
-            {
-                size += 1 + 8;
-            }
-            if (ItemFleeMult != 0D)
-            {
-                size += 1 + 8;
-            }
-            if (StopMovement != false)
-            {
-                size += 1 + 1;
-            }
-            if (StopAttack != false)
-            {
-                size += 1 + 1;
-            }
-            if (TargetMax != false)
-            {
-                size += 1 + 1;
-            }
-            if (TargetSlow != false)
-            {
-                size += 1 + 1;
-            }
-            return size;
-        }
-
-        public void MergeFrom(UseItemCaptureResponse other)
-        {
-            if (other == null)
-            {
-                return;
-            }
-            if (other.Success != false)
-            {
-                Success = other.Success;
-            }
-            if (other.ItemCaptureMult != 0D)
-            {
-                ItemCaptureMult = other.ItemCaptureMult;
-            }
-            if (other.ItemFleeMult != 0D)
-            {
-                ItemFleeMult = other.ItemFleeMult;
-            }
-            if (other.StopMovement != false)
-            {
-                StopMovement = other.StopMovement;
-            }
-            if (other.StopAttack != false)
-            {
-                StopAttack = other.StopAttack;
-            }
-            if (other.TargetMax != false)
-            {
-                TargetMax = other.TargetMax;
-            }
-            if (other.TargetSlow != false)
-            {
-                TargetSlow = other.TargetSlow;
-            }
-        }
-
-        public void MergeFrom(pb::CodedInputStream input)
-        {
-            uint tag;
-            while ((tag = input.ReadTag()) != 0)
-            {
-                switch (tag)
-                {
-                    default:
-                        input.SkipLastField();
-                        break;
-                    case 8:
-                        {
-                            Success = input.ReadBool();
-                            break;
-                        }
-                    case 17:
-                        {
-                            ItemCaptureMult = input.ReadDouble();
-                            break;
-                        }
-                    case 25:
-                        {
-                            ItemFleeMult = input.ReadDouble();
-                            break;
-                        }
-                    case 32:
-                        {
-                            StopMovement = input.ReadBool();
-                            break;
-                        }
-                    case 40:
-                        {
-                            StopAttack = input.ReadBool();
-                            break;
-                        }
-                    case 48:
-                        {
-                            TargetMax = input.ReadBool();
-                            break;
-                        }
-                    case 56:
-                        {
-                            TargetSlow = input.ReadBool();
-                            break;
-                        }
-                }
-            }
-        }
-
-        public override bool Equals(object other)
-        {
-            return Equals(other as UseItemCaptureResponse);
-        }
-
-        public override int GetHashCode()
-        {
-            var hash = 1;
-            if (Success != false) hash ^= Success.GetHashCode();
-            if (ItemCaptureMult != 0D) hash ^= ItemCaptureMult.GetHashCode();
-            if (ItemFleeMult != 0D) hash ^= ItemFleeMult.GetHashCode();
-            if (StopMovement != false) hash ^= StopMovement.GetHashCode();
-            if (StopAttack != false) hash ^= StopAttack.GetHashCode();
-            if (TargetMax != false) hash ^= TargetMax.GetHashCode();
-            if (TargetSlow != false) hash ^= TargetSlow.GetHashCode();
-            return hash;
-        }
-
-        partial void OnConstruction();
-
-        public override string ToString()
-        {
-            return pb::JsonFormatter.ToDiagnosticString(this);
-        }
-    }
-
-    [global::System.Diagnostics.DebuggerNonUserCodeAttribute()]
-    public sealed partial class ReleasePokemonRequest : pb::IMessage<ReleasePokemonRequest>
-    {
-        /// <summary>Field number for the "pokemon_id" field.</summary>
-        public const int PokemonIdFieldNumber = 1;
-
-        private static readonly pb::MessageParser<ReleasePokemonRequest> _parser =
-            new pb::MessageParser<ReleasePokemonRequest>(() => new ReleasePokemonRequest());
-
-        private ulong pokemonId_;
-
-        public ReleasePokemonRequest()
-        {
-            OnConstruction();
-        }
-
-        public ReleasePokemonRequest(ReleasePokemonRequest other) : this()
-        {
-            pokemonId_ = other.pokemonId_;
-        }
-
-        public static pb::MessageParser<ReleasePokemonRequest> Parser
-        {
-            get { return _parser; }
-        }
-
-        public static pbr::MessageDescriptor Descriptor
-        {
-            get { return global::PokemonGo.RocketAPI.GeneratedCode.PayloadsReflection.Descriptor.MessageTypes[47]; }
-        }
-
-        public ulong PokemonId
-        {
-            get { return pokemonId_; }
-            set { pokemonId_ = value; }
-        }
-
-        pbr::MessageDescriptor pb::IMessage.Descriptor
-        {
-            get { return Descriptor; }
-        }
-
-        public ReleasePokemonRequest Clone()
-        {
-            return new ReleasePokemonRequest(this);
-        }
-
-        public bool Equals(ReleasePokemonRequest other)
-        {
-            if (ReferenceEquals(other, null))
-            {
-                return false;
-            }
-            if (ReferenceEquals(other, this))
-            {
-                return true;
-            }
-            if (PokemonId != other.PokemonId) return false;
-            return true;
-        }
-
-        public void WriteTo(pb::CodedOutputStream output)
-        {
-            if (PokemonId != 0UL)
-            {
-                output.WriteRawTag(9);
-                output.WriteFixed64(PokemonId);
-            }
-        }
-
-        public int CalculateSize()
-        {
-            var size = 0;
-            if (PokemonId != 0UL)
-            {
-                size += 1 + 8;
-            }
-            return size;
-        }
-
-        public void MergeFrom(ReleasePokemonRequest other)
-        {
-            if (other == null)
-            {
-                return;
-            }
-            if (other.PokemonId != 0UL)
-            {
-                PokemonId = other.PokemonId;
-            }
-        }
-
-        public void MergeFrom(pb::CodedInputStream input)
-        {
-            uint tag;
-            while ((tag = input.ReadTag()) != 0)
-            {
-                switch (tag)
-                {
-                    default:
-                        input.SkipLastField();
-                        break;
-                    case 9:
-                        {
-                            PokemonId = input.ReadFixed64();
-                            break;
-                        }
-                }
-            }
-        }
-
-        public override bool Equals(object other)
-        {
-            return Equals(other as ReleasePokemonRequest);
-        }
-
-        public override int GetHashCode()
-        {
-            var hash = 1;
-            if (PokemonId != 0UL) hash ^= PokemonId.GetHashCode();
-            return hash;
-        }
-
-        partial void OnConstruction();
-
-        public override string ToString()
-        {
-            return pb::JsonFormatter.ToDiagnosticString(this);
-        }
-    }
-
-    [global::System.Diagnostics.DebuggerNonUserCodeAttribute()]
-    public sealed partial class ReleasePokemonResponse : pb::IMessage<ReleasePokemonResponse>
-    {
-        /// <summary>Field number for the "result" field.</summary>
-        public const int ResultFieldNumber = 1;
-
-        /// <summary>Field number for the "candy_awarded" field.</summary>
-        public const int CandyAwardedFieldNumber = 2;
-
-        private static readonly pb::MessageParser<ReleasePokemonResponse> _parser =
-            new pb::MessageParser<ReleasePokemonResponse>(() => new ReleasePokemonResponse());
-
-        private int candyAwarded_;
-        private global::PokemonGo.RocketAPI.GeneratedCode.ReleasePokemonResponse.Types.Result result_ = 0;
-
-        public ReleasePokemonResponse()
-        {
-            OnConstruction();
-        }
-
-        public ReleasePokemonResponse(ReleasePokemonResponse other) : this()
-        {
-            result_ = other.result_;
-            candyAwarded_ = other.candyAwarded_;
-        }
-
-        public static pb::MessageParser<ReleasePokemonResponse> Parser
-        {
-            get { return _parser; }
-        }
-
-        public static pbr::MessageDescriptor Descriptor
-        {
-            get { return global::PokemonGo.RocketAPI.GeneratedCode.PayloadsReflection.Descriptor.MessageTypes[48]; }
-        }
-
-        public global::PokemonGo.RocketAPI.GeneratedCode.ReleasePokemonResponse.Types.Result Result
-        {
-            get { return result_; }
-            set { result_ = value; }
-        }
-
-        public int CandyAwarded
-        {
-            get { return candyAwarded_; }
-            set { candyAwarded_ = value; }
-        }
-
-        pbr::MessageDescriptor pb::IMessage.Descriptor
-        {
-            get { return Descriptor; }
-        }
-
-        public ReleasePokemonResponse Clone()
-        {
-            return new ReleasePokemonResponse(this);
-        }
-
-        public bool Equals(ReleasePokemonResponse other)
-        {
-            if (ReferenceEquals(other, null))
-            {
-                return false;
-            }
-            if (ReferenceEquals(other, this))
-            {
-                return true;
-            }
-            if (Result != other.Result) return false;
-            if (CandyAwarded != other.CandyAwarded) return false;
-            return true;
-        }
-
-        public void WriteTo(pb::CodedOutputStream output)
-        {
-            if (Result != 0)
-            {
-                output.WriteRawTag(8);
-                output.WriteEnum((int)Result);
-            }
-            if (CandyAwarded != 0)
-            {
-                output.WriteRawTag(16);
-                output.WriteInt32(CandyAwarded);
-            }
-        }
-
-        public int CalculateSize()
-        {
-            var size = 0;
-            if (Result != 0)
-            {
-                size += 1 + pb::CodedOutputStream.ComputeEnumSize((int)Result);
-            }
-            if (CandyAwarded != 0)
-            {
-                size += 1 + pb::CodedOutputStream.ComputeInt32Size(CandyAwarded);
-            }
-            return size;
-        }
-
-        public void MergeFrom(ReleasePokemonResponse other)
-        {
-            if (other == null)
-            {
-                return;
-            }
-            if (other.Result != 0)
-            {
-                Result = other.Result;
-            }
-            if (other.CandyAwarded != 0)
-            {
-                CandyAwarded = other.CandyAwarded;
-            }
-        }
-
-        public void MergeFrom(pb::CodedInputStream input)
-        {
-            uint tag;
-            while ((tag = input.ReadTag()) != 0)
-            {
-                switch (tag)
-                {
-                    default:
-                        input.SkipLastField();
-                        break;
-                    case 8:
-                        {
-                            result_ =
-                                (global::PokemonGo.RocketAPI.GeneratedCode.ReleasePokemonResponse.Types.Result)
-                                    input.ReadEnum();
-                            break;
-                        }
-                    case 16:
-                        {
-                            CandyAwarded = input.ReadInt32();
-                            break;
-                        }
-                }
-            }
-        }
-
-        public override bool Equals(object other)
-        {
-            return Equals(other as ReleasePokemonResponse);
-        }
-
-        public override int GetHashCode()
-        {
-            var hash = 1;
-            if (Result != 0) hash ^= Result.GetHashCode();
-            if (CandyAwarded != 0) hash ^= CandyAwarded.GetHashCode();
-            return hash;
-        }
-
-        partial void OnConstruction();
-
-        public override string ToString()
-        {
-            return pb::JsonFormatter.ToDiagnosticString(this);
-        }
-
-        #region Nested types
-
-        /// <summary>Container for nested types declared in the ReleasePokemonResponse message type.</summary>
-        [global::System.Diagnostics.DebuggerNonUserCodeAttribute()]
-        public static partial class Types
-        {
-            public enum Result
-            {
-                [pbr::OriginalName("UNSET")]
-                Unset = 0,
-                [pbr::OriginalName("SUCCESS")]
-                Success = 1,
-                [pbr::OriginalName("POKEMON_DEPLOYED")]
-                PokemonDeployed = 2,
-                [pbr::OriginalName("FAILED")]
-                Failed = 3,
-                [pbr::OriginalName("ERROR_POKEMON_IS_EGG")]
-                ErrorPokemonIsEgg = 4,
-            }
-        }
-
-        #endregion
-    }
-
-    /// <summary>
-    ///     No message needed.
-    /// </summary>
-    [global::System.Diagnostics.DebuggerNonUserCodeAttribute()]
-    public sealed partial class GetHatchedEggsRequest : pb::IMessage<GetHatchedEggsRequest>
-    {
-        private static readonly pb::MessageParser<GetHatchedEggsRequest> _parser =
-            new pb::MessageParser<GetHatchedEggsRequest>(() => new GetHatchedEggsRequest());
-
-        public GetHatchedEggsRequest()
-        {
-            OnConstruction();
-        }
-
-        public GetHatchedEggsRequest(GetHatchedEggsRequest other) : this()
-        {
-        }
-
-        public static pb::MessageParser<GetHatchedEggsRequest> Parser
-        {
-            get { return _parser; }
-        }
-
-        public static pbr::MessageDescriptor Descriptor
-        {
-            get { return global::PokemonGo.RocketAPI.GeneratedCode.PayloadsReflection.Descriptor.MessageTypes[49]; }
-        }
-
-        pbr::MessageDescriptor pb::IMessage.Descriptor
-        {
-            get { return Descriptor; }
-        }
-
-        public GetHatchedEggsRequest Clone()
-        {
-            return new GetHatchedEggsRequest(this);
-        }
-
-        public bool Equals(GetHatchedEggsRequest other)
-        {
-            if (ReferenceEquals(other, null))
-            {
-                return false;
-            }
-            if (ReferenceEquals(other, this))
-            {
-                return true;
-            }
-            return true;
-        }
-
-        public void WriteTo(pb::CodedOutputStream output)
-        {
-        }
-
-        public int CalculateSize()
-        {
-            var size = 0;
-            return size;
-        }
-
-        public void MergeFrom(GetHatchedEggsRequest other)
-        {
-            if (other == null)
-            {
-                return;
-            }
-        }
-
-        public void MergeFrom(pb::CodedInputStream input)
-        {
-            uint tag;
-            while ((tag = input.ReadTag()) != 0)
-            {
-                switch (tag)
-                {
-                    default:
-                        input.SkipLastField();
-                        break;
-                }
-            }
-        }
-
-        public override bool Equals(object other)
-        {
-            return Equals(other as GetHatchedEggsRequest);
-        }
-
-        public override int GetHashCode()
-        {
-            var hash = 1;
-            return hash;
-        }
-
-        partial void OnConstruction();
-
-        public override string ToString()
-        {
-            return pb::JsonFormatter.ToDiagnosticString(this);
-        }
-    }
-
-    /// <summary>
-    ///     Confirm if this is correct, I think that it should be "repeated HatchedEgg hatched_eggs" or something like that.
-    /// </summary>
-    [global::System.Diagnostics.DebuggerNonUserCodeAttribute()]
-    public sealed partial class GetHatchedEggsResponse : pb::IMessage<GetHatchedEggsResponse>
-    {
-        /// <summary>Field number for the "success" field.</summary>
-        public const int SuccessFieldNumber = 1;
-
-        /// <summary>Field number for the "pokemon_id" field.</summary>
-        public const int PokemonIdFieldNumber = 2;
-
-        /// <summary>Field number for the "experience_awarded" field.</summary>
-        public const int ExperienceAwardedFieldNumber = 3;
-
-        /// <summary>Field number for the "candy_awarded" field.</summary>
-        public const int CandyAwardedFieldNumber = 4;
-
-        /// <summary>Field number for the "stardust_awarded" field.</summary>
-        public const int StardustAwardedFieldNumber = 5;
-
-        private static readonly pb::MessageParser<GetHatchedEggsResponse> _parser =
-            new pb::MessageParser<GetHatchedEggsResponse>(() => new GetHatchedEggsResponse());
-
-        private static readonly pb::FieldCodec<ulong> _repeated_pokemonId_codec
-            = pb::FieldCodec.ForUInt64(18);
-
-        private static readonly pb::FieldCodec<int> _repeated_experienceAwarded_codec
-            = pb::FieldCodec.ForInt32(26);
-
-        private static readonly pb::FieldCodec<int> _repeated_candyAwarded_codec
-            = pb::FieldCodec.ForInt32(34);
-
-        private static readonly pb::FieldCodec<int> _repeated_stardustAwarded_codec
-            = pb::FieldCodec.ForInt32(42);
-
-        private readonly pbc::RepeatedField<int> candyAwarded_ = new pbc::RepeatedField<int>();
-        private readonly pbc::RepeatedField<int> experienceAwarded_ = new pbc::RepeatedField<int>();
-        private readonly pbc::RepeatedField<ulong> pokemonId_ = new pbc::RepeatedField<ulong>();
-        private readonly pbc::RepeatedField<int> stardustAwarded_ = new pbc::RepeatedField<int>();
-        private bool success_;
-
-        public GetHatchedEggsResponse()
-        {
-            OnConstruction();
-        }
-
-        public GetHatchedEggsResponse(GetHatchedEggsResponse other) : this()
-        {
-            success_ = other.success_;
-            pokemonId_ = other.pokemonId_.Clone();
-            experienceAwarded_ = other.experienceAwarded_.Clone();
-            candyAwarded_ = other.candyAwarded_.Clone();
-            stardustAwarded_ = other.stardustAwarded_.Clone();
-        }
-
-        public static pb::MessageParser<GetHatchedEggsResponse> Parser
-        {
-            get { return _parser; }
-        }
-
-        public static pbr::MessageDescriptor Descriptor
-        {
-            get { return global::PokemonGo.RocketAPI.GeneratedCode.PayloadsReflection.Descriptor.MessageTypes[50]; }
-        }
-
-        public bool Success
-        {
-            get { return success_; }
-            set { success_ = value; }
-        }
-
-        /// <summary>
-        ///     Might be POGOProtos.Enums.Pokemon
-        /// </summary>
-        public pbc::RepeatedField<ulong> PokemonId
-        {
-            get { return pokemonId_; }
-        }
-
-        public pbc::RepeatedField<int> ExperienceAwarded
-        {
-            get { return experienceAwarded_; }
-        }
-
-        public pbc::RepeatedField<int> CandyAwarded
-        {
-            get { return candyAwarded_; }
-        }
-
-        public pbc::RepeatedField<int> StardustAwarded
-        {
-            get { return stardustAwarded_; }
-        }
-
-        pbr::MessageDescriptor pb::IMessage.Descriptor
-        {
-            get { return Descriptor; }
-        }
-
-        public GetHatchedEggsResponse Clone()
-        {
-            return new GetHatchedEggsResponse(this);
-        }
-
-        public bool Equals(GetHatchedEggsResponse other)
-        {
-            if (ReferenceEquals(other, null))
-            {
-                return false;
-            }
-            if (ReferenceEquals(other, this))
-            {
-                return true;
-            }
-            if (Success != other.Success) return false;
-            if (!pokemonId_.Equals(other.pokemonId_)) return false;
-            if (!experienceAwarded_.Equals(other.experienceAwarded_)) return false;
-            if (!candyAwarded_.Equals(other.candyAwarded_)) return false;
-            if (!stardustAwarded_.Equals(other.stardustAwarded_)) return false;
-            return true;
-        }
-
-        public void WriteTo(pb::CodedOutputStream output)
-        {
-            if (Success != false)
-            {
-                output.WriteRawTag(8);
-                output.WriteBool(Success);
-            }
-            pokemonId_.WriteTo(output, _repeated_pokemonId_codec);
-            experienceAwarded_.WriteTo(output, _repeated_experienceAwarded_codec);
-            candyAwarded_.WriteTo(output, _repeated_candyAwarded_codec);
-            stardustAwarded_.WriteTo(output, _repeated_stardustAwarded_codec);
-        }
-
-        public int CalculateSize()
-        {
-            var size = 0;
-            if (Success != false)
-            {
-                size += 1 + 1;
-            }
-            size += pokemonId_.CalculateSize(_repeated_pokemonId_codec);
-            size += experienceAwarded_.CalculateSize(_repeated_experienceAwarded_codec);
-            size += candyAwarded_.CalculateSize(_repeated_candyAwarded_codec);
-            size += stardustAwarded_.CalculateSize(_repeated_stardustAwarded_codec);
-            return size;
-        }
-
-        public void MergeFrom(GetHatchedEggsResponse other)
-        {
-            if (other == null)
-            {
-                return;
-            }
-            if (other.Success != false)
-            {
-                Success = other.Success;
-            }
-            pokemonId_.Add(other.pokemonId_);
-            experienceAwarded_.Add(other.experienceAwarded_);
-            candyAwarded_.Add(other.candyAwarded_);
-            stardustAwarded_.Add(other.stardustAwarded_);
-        }
-
-        public void MergeFrom(pb::CodedInputStream input)
-        {
-            uint tag;
-            while ((tag = input.ReadTag()) != 0)
-            {
-                switch (tag)
-                {
-                    default:
-                        input.SkipLastField();
-                        break;
-                    case 8:
-                        {
-                            Success = input.ReadBool();
-                            break;
-                        }
-                    case 18:
-                    case 16:
-                        {
-                            pokemonId_.AddEntriesFrom(input, _repeated_pokemonId_codec);
-                            break;
-                        }
-                    case 26:
-                    case 24:
-                        {
-                            experienceAwarded_.AddEntriesFrom(input, _repeated_experienceAwarded_codec);
-                            break;
-                        }
-                    case 34:
-                    case 32:
-                        {
-                            candyAwarded_.AddEntriesFrom(input, _repeated_candyAwarded_codec);
-                            break;
-                        }
-                    case 42:
-                    case 40:
-                        {
-                            stardustAwarded_.AddEntriesFrom(input, _repeated_stardustAwarded_codec);
-                            break;
-                        }
-                }
-            }
-        }
-
-        public override bool Equals(object other)
-        {
-            return Equals(other as GetHatchedEggsResponse);
-        }
-
-        public override int GetHashCode()
-        {
-            var hash = 1;
-            if (Success != false) hash ^= Success.GetHashCode();
-            hash ^= pokemonId_.GetHashCode();
-            hash ^= experienceAwarded_.GetHashCode();
-            hash ^= candyAwarded_.GetHashCode();
-            hash ^= stardustAwarded_.GetHashCode();
-            return hash;
-        }
-
-        partial void OnConstruction();
-
-        public override string ToString()
-        {
-            return pb::JsonFormatter.ToDiagnosticString(this);
-        }
-    }
-
-    [global::System.Diagnostics.DebuggerNonUserCodeAttribute()]
-    public sealed partial class FortSearchRequest : pb::IMessage<FortSearchRequest>
-    {
-        /// <summary>Field number for the "fort_id" field.</summary>
-        public const int FortIdFieldNumber = 1;
-
-        /// <summary>Field number for the "player_latitude" field.</summary>
-        public const int PlayerLatitudeFieldNumber = 2;
-
-        /// <summary>Field number for the "player_longitude" field.</summary>
-        public const int PlayerLongitudeFieldNumber = 3;
-
-        /// <summary>Field number for the "fort_latitude" field.</summary>
-        public const int FortLatitudeFieldNumber = 4;
-
-        /// <summary>Field number for the "fort_longitude" field.</summary>
-        public const int FortLongitudeFieldNumber = 5;
-
-        private static readonly pb::MessageParser<FortSearchRequest> _parser =
-            new pb::MessageParser<FortSearchRequest>(() => new FortSearchRequest());
-
-        private string fortId_ = "";
-        private double fortLatitude_;
-        private double fortLongitude_;
-        private double playerLatitude_;
-        private double playerLongitude_;
-
-        public FortSearchRequest()
-        {
-            OnConstruction();
-        }
-
-        public FortSearchRequest(FortSearchRequest other) : this()
-        {
-            fortId_ = other.fortId_;
-            playerLatitude_ = other.playerLatitude_;
-            playerLongitude_ = other.playerLongitude_;
-            fortLatitude_ = other.fortLatitude_;
-            fortLongitude_ = other.fortLongitude_;
-        }
-
-        public static pb::MessageParser<FortSearchRequest> Parser
-        {
-            get { return _parser; }
-        }
-
-        public static pbr::MessageDescriptor Descriptor
-        {
-            get { return global::PokemonGo.RocketAPI.GeneratedCode.PayloadsReflection.Descriptor.MessageTypes[51]; }
-        }
-
-        public string FortId
-        {
-            get { return fortId_; }
-            set { fortId_ = pb::ProtoPreconditions.CheckNotNull(value, "value"); }
-        }
-
-        public double PlayerLatitude
-        {
-            get { return playerLatitude_; }
-            set { playerLatitude_ = value; }
-        }
-
-        public double PlayerLongitude
-        {
-            get { return playerLongitude_; }
-            set { playerLongitude_ = value; }
-        }
-
-        public double FortLatitude
-        {
-            get { return fortLatitude_; }
-            set { fortLatitude_ = value; }
-        }
-
-        public double FortLongitude
-        {
-            get { return fortLongitude_; }
-            set { fortLongitude_ = value; }
-        }
-
-        pbr::MessageDescriptor pb::IMessage.Descriptor
-        {
-            get { return Descriptor; }
-        }
-
-        public FortSearchRequest Clone()
-        {
-            return new FortSearchRequest(this);
-        }
-
-        public bool Equals(FortSearchRequest other)
-        {
-            if (ReferenceEquals(other, null))
-            {
-                return false;
-            }
-            if (ReferenceEquals(other, this))
-            {
-                return true;
-            }
-            if (FortId != other.FortId) return false;
-            if (PlayerLatitude != other.PlayerLatitude) return false;
-            if (PlayerLongitude != other.PlayerLongitude) return false;
-            if (FortLatitude != other.FortLatitude) return false;
-            if (FortLongitude != other.FortLongitude) return false;
-            return true;
-        }
-
-        public void WriteTo(pb::CodedOutputStream output)
-        {
-            if (FortId.Length != 0)
-            {
-                output.WriteRawTag(10);
-                output.WriteString(FortId);
-            }
-            if (PlayerLatitude != 0D)
-            {
-                output.WriteRawTag(17);
-                output.WriteDouble(PlayerLatitude);
-            }
-            if (PlayerLongitude != 0D)
-            {
-                output.WriteRawTag(25);
-                output.WriteDouble(PlayerLongitude);
-            }
-            if (FortLatitude != 0D)
-            {
-                output.WriteRawTag(33);
-                output.WriteDouble(FortLatitude);
-            }
-            if (FortLongitude != 0D)
-            {
-                output.WriteRawTag(41);
-                output.WriteDouble(FortLongitude);
-            }
-        }
-
-        public int CalculateSize()
-        {
-            var size = 0;
-            if (FortId.Length != 0)
-            {
-                size += 1 + pb::CodedOutputStream.ComputeStringSize(FortId);
-            }
-            if (PlayerLatitude != 0D)
-            {
-                size += 1 + 8;
-            }
-            if (PlayerLongitude != 0D)
-            {
-                size += 1 + 8;
-            }
-            if (FortLatitude != 0D)
-            {
-                size += 1 + 8;
-            }
-            if (FortLongitude != 0D)
-            {
-                size += 1 + 8;
-            }
-            return size;
-        }
-
-        public void MergeFrom(FortSearchRequest other)
-        {
-            if (other == null)
-            {
-                return;
-            }
-            if (other.FortId.Length != 0)
-            {
-                FortId = other.FortId;
-            }
-            if (other.PlayerLatitude != 0D)
-            {
-                PlayerLatitude = other.PlayerLatitude;
-            }
-            if (other.PlayerLongitude != 0D)
-            {
-                PlayerLongitude = other.PlayerLongitude;
-            }
-            if (other.FortLatitude != 0D)
-            {
-                FortLatitude = other.FortLatitude;
-            }
-            if (other.FortLongitude != 0D)
-            {
-                FortLongitude = other.FortLongitude;
-            }
-        }
-
-        public void MergeFrom(pb::CodedInputStream input)
-        {
-            uint tag;
-            while ((tag = input.ReadTag()) != 0)
-            {
-                switch (tag)
-                {
-                    default:
-                        input.SkipLastField();
-                        break;
-                    case 10:
-                        {
-                            FortId = input.ReadString();
-                            break;
-                        }
-                    case 17:
-                        {
-                            PlayerLatitude = input.ReadDouble();
-                            break;
-                        }
-                    case 25:
-                        {
-                            PlayerLongitude = input.ReadDouble();
-                            break;
-                        }
-                    case 33:
-                        {
-                            FortLatitude = input.ReadDouble();
-                            break;
-                        }
-                    case 41:
-                        {
-                            FortLongitude = input.ReadDouble();
-                            break;
-                        }
-                }
-            }
-        }
-
-        public override bool Equals(object other)
-        {
-            return Equals(other as FortSearchRequest);
-        }
-
-        public override int GetHashCode()
-        {
-            var hash = 1;
-            if (FortId.Length != 0) hash ^= FortId.GetHashCode();
-            if (PlayerLatitude != 0D) hash ^= PlayerLatitude.GetHashCode();
-            if (PlayerLongitude != 0D) hash ^= PlayerLongitude.GetHashCode();
-            if (FortLatitude != 0D) hash ^= FortLatitude.GetHashCode();
-            if (FortLongitude != 0D) hash ^= FortLongitude.GetHashCode();
-            return hash;
-        }
-
-        partial void OnConstruction();
-
-        public override string ToString()
-        {
-            return pb::JsonFormatter.ToDiagnosticString(this);
-        }
-    }
-
-    [global::System.Diagnostics.DebuggerNonUserCodeAttribute()]
-    public sealed partial class FortSearchResponse : pb::IMessage<FortSearchResponse>
-    {
-        /// <summary>Field number for the "result" field.</summary>
-        public const int ResultFieldNumber = 1;
-
-        /// <summary>Field number for the "items_awarded" field.</summary>
-        public const int ItemsAwardedFieldNumber = 2;
-
-        /// <summary>Field number for the "gems_awarded" field.</summary>
-        public const int GemsAwardedFieldNumber = 3;
-
-        /// <summary>Field number for the "pokemon_data_egg" field.</summary>
-        public const int PokemonDataEggFieldNumber = 4;
-
-        /// <summary>Field number for the "experience_awarded" field.</summary>
-        public const int ExperienceAwardedFieldNumber = 5;
-
-        /// <summary>Field number for the "cooldown_complete_timestamp_ms" field.</summary>
-        public const int CooldownCompleteTimestampMsFieldNumber = 6;
-
-        /// <summary>Field number for the "chain_hack_sequence_number" field.</summary>
-        public const int ChainHackSequenceNumberFieldNumber = 7;
-
-        private static readonly pb::MessageParser<FortSearchResponse> _parser =
-            new pb::MessageParser<FortSearchResponse>(() => new FortSearchResponse());
-
-        private static readonly
-            pb::FieldCodec<global::PokemonGo.RocketAPI.GeneratedCode.FortSearchResponse.Types.ItemAward>
-            _repeated_itemsAwarded_codec
-                = pb::FieldCodec.ForMessage(18,
-                    global::PokemonGo.RocketAPI.GeneratedCode.FortSearchResponse.Types.ItemAward.Parser);
-
-        private readonly
-            pbc::RepeatedField<global::PokemonGo.RocketAPI.GeneratedCode.FortSearchResponse.Types.ItemAward>
-            itemsAwarded_ =
-                new pbc::RepeatedField<global::PokemonGo.RocketAPI.GeneratedCode.FortSearchResponse.Types.ItemAward>();
-
-        private int chainHackSequenceNumber_;
-        private long cooldownCompleteTimestampMs_;
-        private int experienceAwarded_;
-        private int gemsAwarded_;
-        private PokemonData pokemonDataEgg_;
-        private global::PokemonGo.RocketAPI.GeneratedCode.FortSearchResponse.Types.Result result_ = 0;
-
-        public FortSearchResponse()
-        {
-            OnConstruction();
-        }
-
-        public FortSearchResponse(FortSearchResponse other) : this()
-        {
-            result_ = other.result_;
-            itemsAwarded_ = other.itemsAwarded_.Clone();
-            gemsAwarded_ = other.gemsAwarded_;
-            PokemonDataEgg = other.pokemonDataEgg_ != null ? other.PokemonDataEgg.Clone() : null;
-            experienceAwarded_ = other.experienceAwarded_;
-            cooldownCompleteTimestampMs_ = other.cooldownCompleteTimestampMs_;
-            chainHackSequenceNumber_ = other.chainHackSequenceNumber_;
-        }
-
-        public static pb::MessageParser<FortSearchResponse> Parser
-        {
-            get { return _parser; }
-        }
-
-        public static pbr::MessageDescriptor Descriptor
-        {
-            get { return global::PokemonGo.RocketAPI.GeneratedCode.PayloadsReflection.Descriptor.MessageTypes[52]; }
-        }
-
-        public global::PokemonGo.RocketAPI.GeneratedCode.FortSearchResponse.Types.Result Result
-        {
-            get { return result_; }
-            set { result_ = value; }
-        }
-
-        public pbc::RepeatedField<global::PokemonGo.RocketAPI.GeneratedCode.FortSearchResponse.Types.ItemAward>
-            ItemsAwarded
-        {
-            get { return itemsAwarded_; }
-        }
-
-        public int GemsAwarded
-        {
-            get { return gemsAwarded_; }
-            set { gemsAwarded_ = value; }
-        }
-
-        public global::PokemonGo.RocketAPI.GeneratedCode.PokemonData PokemonDataEgg
-        {
-            get { return pokemonDataEgg_; }
-            set { pokemonDataEgg_ = value; }
-        }
-
-        public int ExperienceAwarded
-        {
-            get { return experienceAwarded_; }
-            set { experienceAwarded_ = value; }
-        }
-
-        public long CooldownCompleteTimestampMs
-        {
-            get { return cooldownCompleteTimestampMs_; }
-            set { cooldownCompleteTimestampMs_ = value; }
-        }
-
-        public int ChainHackSequenceNumber
-        {
-            get { return chainHackSequenceNumber_; }
-            set { chainHackSequenceNumber_ = value; }
-        }
-
-        pbr::MessageDescriptor pb::IMessage.Descriptor
-        {
-            get { return Descriptor; }
-        }
-
-        public FortSearchResponse Clone()
-        {
-            return new FortSearchResponse(this);
-        }
-
-        public bool Equals(FortSearchResponse other)
-        {
-            if (ReferenceEquals(other, null))
-            {
-                return false;
-            }
-            if (ReferenceEquals(other, this))
-            {
-                return true;
-            }
-            if (Result != other.Result) return false;
-            if (!itemsAwarded_.Equals(other.itemsAwarded_)) return false;
-            if (GemsAwarded != other.GemsAwarded) return false;
-            if (!Equals(PokemonDataEgg, other.PokemonDataEgg)) return false;
-            if (ExperienceAwarded != other.ExperienceAwarded) return false;
-            if (CooldownCompleteTimestampMs != other.CooldownCompleteTimestampMs) return false;
-            if (ChainHackSequenceNumber != other.ChainHackSequenceNumber) return false;
-            return true;
-        }
-
-        public void WriteTo(pb::CodedOutputStream output)
-        {
-            if (Result != 0)
-            {
-                output.WriteRawTag(8);
-                output.WriteEnum((int)Result);
-            }
-            itemsAwarded_.WriteTo(output, _repeated_itemsAwarded_codec);
-            if (GemsAwarded != 0)
-            {
-                output.WriteRawTag(24);
-                output.WriteInt32(GemsAwarded);
-            }
-            if (pokemonDataEgg_ != null)
-            {
-                output.WriteRawTag(34);
-                output.WriteMessage(PokemonDataEgg);
-            }
-            if (ExperienceAwarded != 0)
-            {
-                output.WriteRawTag(40);
-                output.WriteInt32(ExperienceAwarded);
-            }
-            if (CooldownCompleteTimestampMs != 0L)
-            {
-                output.WriteRawTag(48);
-                output.WriteInt64(CooldownCompleteTimestampMs);
-            }
-            if (ChainHackSequenceNumber != 0)
-            {
-                output.WriteRawTag(56);
-                output.WriteInt32(ChainHackSequenceNumber);
-            }
-        }
-
-        public int CalculateSize()
-        {
-            var size = 0;
-            if (Result != 0)
-            {
-                size += 1 + pb::CodedOutputStream.ComputeEnumSize((int)Result);
-            }
-            size += itemsAwarded_.CalculateSize(_repeated_itemsAwarded_codec);
-            if (GemsAwarded != 0)
-            {
-                size += 1 + pb::CodedOutputStream.ComputeInt32Size(GemsAwarded);
-            }
-            if (pokemonDataEgg_ != null)
-            {
-                size += 1 + pb::CodedOutputStream.ComputeMessageSize(PokemonDataEgg);
-            }
-            if (ExperienceAwarded != 0)
-            {
-                size += 1 + pb::CodedOutputStream.ComputeInt32Size(ExperienceAwarded);
-            }
-            if (CooldownCompleteTimestampMs != 0L)
-            {
-                size += 1 + pb::CodedOutputStream.ComputeInt64Size(CooldownCompleteTimestampMs);
-            }
-            if (ChainHackSequenceNumber != 0)
-            {
-                size += 1 + pb::CodedOutputStream.ComputeInt32Size(ChainHackSequenceNumber);
-            }
-            return size;
-        }
-
-        public void MergeFrom(FortSearchResponse other)
-        {
-            if (other == null)
-            {
-                return;
-            }
-            if (other.Result != 0)
-            {
-                Result = other.Result;
-            }
-            itemsAwarded_.Add(other.itemsAwarded_);
-            if (other.GemsAwarded != 0)
-            {
-                GemsAwarded = other.GemsAwarded;
-            }
-            if (other.pokemonDataEgg_ != null)
-            {
-                if (pokemonDataEgg_ == null)
-                {
-                    pokemonDataEgg_ = new global::PokemonGo.RocketAPI.GeneratedCode.PokemonData();
-                }
-                PokemonDataEgg.MergeFrom(other.PokemonDataEgg);
-            }
-            if (other.ExperienceAwarded != 0)
-            {
-                ExperienceAwarded = other.ExperienceAwarded;
-            }
-            if (other.CooldownCompleteTimestampMs != 0L)
-            {
-                CooldownCompleteTimestampMs = other.CooldownCompleteTimestampMs;
-            }
-            if (other.ChainHackSequenceNumber != 0)
-            {
-                ChainHackSequenceNumber = other.ChainHackSequenceNumber;
-            }
-        }
-
-        public void MergeFrom(pb::CodedInputStream input)
-        {
-            uint tag;
-            while ((tag = input.ReadTag()) != 0)
-            {
-                switch (tag)
-                {
-                    default:
-                        input.SkipLastField();
-                        break;
-                    case 8:
-                        {
-                            result_ =
-                                (global::PokemonGo.RocketAPI.GeneratedCode.FortSearchResponse.Types.Result)input.ReadEnum();
-                            break;
-                        }
-                    case 18:
-                        {
-                            itemsAwarded_.AddEntriesFrom(input, _repeated_itemsAwarded_codec);
-                            break;
-                        }
-                    case 24:
-                        {
-                            GemsAwarded = input.ReadInt32();
-                            break;
-                        }
-                    case 34:
-                        {
-                            if (pokemonDataEgg_ == null)
-                            {
-                                pokemonDataEgg_ = new global::PokemonGo.RocketAPI.GeneratedCode.PokemonData();
-                            }
-                            input.ReadMessage(pokemonDataEgg_);
-                            break;
-                        }
-                    case 40:
-                        {
-                            ExperienceAwarded = input.ReadInt32();
-                            break;
-                        }
-                    case 48:
-                        {
-                            CooldownCompleteTimestampMs = input.ReadInt64();
-                            break;
-                        }
-                    case 56:
-                        {
-                            ChainHackSequenceNumber = input.ReadInt32();
-                            break;
-                        }
-                }
-            }
-        }
-
-        public override bool Equals(object other)
-        {
-            return Equals(other as FortSearchResponse);
-        }
-
-        public override int GetHashCode()
-        {
-            var hash = 1;
-            if (Result != 0) hash ^= Result.GetHashCode();
-            hash ^= itemsAwarded_.GetHashCode();
-            if (GemsAwarded != 0) hash ^= GemsAwarded.GetHashCode();
-            if (pokemonDataEgg_ != null) hash ^= PokemonDataEgg.GetHashCode();
-            if (ExperienceAwarded != 0) hash ^= ExperienceAwarded.GetHashCode();
-            if (CooldownCompleteTimestampMs != 0L) hash ^= CooldownCompleteTimestampMs.GetHashCode();
-            if (ChainHackSequenceNumber != 0) hash ^= ChainHackSequenceNumber.GetHashCode();
-            return hash;
-        }
-
-        partial void OnConstruction();
-
-        public override string ToString()
-        {
-            return pb::JsonFormatter.ToDiagnosticString(this);
-        }
-
-        #region Nested types
-
-        /// <summary>Container for nested types declared in the FortSearchResponse message type.</summary>
-        [global::System.Diagnostics.DebuggerNonUserCodeAttribute()]
-        public static partial class Types
-        {
-            public enum Result
-            {
-                [pbr::OriginalName("NO_RESULT_SET")]
-                NoResultSet = 0,
-                [pbr::OriginalName("SUCCESS")]
-                Success = 1,
-                [pbr::OriginalName("OUT_OF_RANGE")]
-                OutOfRange = 2,
-                [pbr::OriginalName("IN_COOLDOWN_PERIOD")]
-                InCooldownPeriod = 3,
-                [pbr::OriginalName("INVENTORY_FULL")]
-                InventoryFull = 4,
-            }
-
-            [global::System.Diagnostics.DebuggerNonUserCodeAttribute()]
-            public sealed partial class ItemAward : pb::IMessage<ItemAward>
-            {
-                /// <summary>Field number for the "item_id" field.</summary>
-                public const int ItemIdFieldNumber = 1;
-
-                /// <summary>Field number for the "item_count" field.</summary>
-                public const int ItemCountFieldNumber = 2;
-
-                private static readonly pb::MessageParser<ItemAward> _parser =
-                    new pb::MessageParser<ItemAward>(() => new ItemAward());
-
-                private int itemCount_;
-                private global::PokemonGo.RocketAPI.GeneratedCode.ItemId itemId_ = 0;
-
-                public ItemAward()
-                {
-                    OnConstruction();
-                }
-
-                public ItemAward(ItemAward other) : this()
-                {
-                    itemId_ = other.itemId_;
-                    itemCount_ = other.itemCount_;
-                }
-
-                public static pb::MessageParser<ItemAward> Parser
-                {
-                    get { return _parser; }
-                }
-
-                public static pbr::MessageDescriptor Descriptor
-                {
-                    get
-                    {
-                        return global::PokemonGo.RocketAPI.GeneratedCode.FortSearchResponse.Descriptor.NestedTypes[0];
-                    }
-                }
-
-                public global::PokemonGo.RocketAPI.GeneratedCode.ItemId ItemId
-                {
-                    get { return itemId_; }
-                    set { itemId_ = value; }
-                }
-
-                public int ItemCount
-                {
-                    get { return itemCount_; }
-                    set { itemCount_ = value; }
-                }
-
-                pbr::MessageDescriptor pb::IMessage.Descriptor
-                {
-                    get { return Descriptor; }
-                }
-
-                public ItemAward Clone()
-                {
-                    return new ItemAward(this);
-                }
-
-                public bool Equals(ItemAward other)
-                {
-                    if (ReferenceEquals(other, null))
-                    {
-                        return false;
-                    }
-                    if (ReferenceEquals(other, this))
-                    {
-                        return true;
-                    }
-                    if (ItemId != other.ItemId) return false;
-                    if (ItemCount != other.ItemCount) return false;
-                    return true;
-                }
-
-                public void WriteTo(pb::CodedOutputStream output)
-                {
-                    if (ItemId != 0)
-                    {
-                        output.WriteRawTag(8);
-                        output.WriteEnum((int)ItemId);
-                    }
-                    if (ItemCount != 0)
-                    {
-                        output.WriteRawTag(16);
-                        output.WriteInt32(ItemCount);
-                    }
-                }
-
-                public int CalculateSize()
-                {
-                    var size = 0;
-                    if (ItemId != 0)
-                    {
-                        size += 1 + pb::CodedOutputStream.ComputeEnumSize((int)ItemId);
-                    }
-                    if (ItemCount != 0)
-                    {
-                        size += 1 + pb::CodedOutputStream.ComputeInt32Size(ItemCount);
-                    }
-                    return size;
-                }
-
-                public void MergeFrom(ItemAward other)
-                {
-                    if (other == null)
-                    {
-                        return;
-                    }
-                    if (other.ItemId != 0)
-                    {
-                        ItemId = other.ItemId;
-                    }
-                    if (other.ItemCount != 0)
-                    {
-                        ItemCount = other.ItemCount;
-                    }
-                }
-
-                public void MergeFrom(pb::CodedInputStream input)
-                {
-                    uint tag;
-                    while ((tag = input.ReadTag()) != 0)
-                    {
-                        switch (tag)
-                        {
-                            default:
-                                input.SkipLastField();
-                                break;
-                            case 8:
-                                {
-                                    itemId_ = (global::PokemonGo.RocketAPI.GeneratedCode.ItemId)input.ReadEnum();
-                                    break;
-                                }
-                            case 16:
-                                {
-                                    ItemCount = input.ReadInt32();
-                                    break;
-                                }
-                        }
-                    }
-                }
-
-                public override bool Equals(object other)
-                {
-                    return Equals(other as ItemAward);
-                }
-
-                public override int GetHashCode()
-                {
-                    var hash = 1;
-                    if (ItemId != 0) hash ^= ItemId.GetHashCode();
-                    if (ItemCount != 0) hash ^= ItemCount.GetHashCode();
-                    return hash;
-                }
-
-                partial void OnConstruction();
-
-                public override string ToString()
-                {
-                    return pb::JsonFormatter.ToDiagnosticString(this);
-                }
-            }
-        }
-
-        #endregion
-    }
-
-    [global::System.Diagnostics.DebuggerNonUserCodeAttribute()]
-    public sealed partial class FortDetailsRequest : pb::IMessage<FortDetailsRequest>
-    {
-        /// <summary>Field number for the "fort_id" field.</summary>
-        public const int FortIdFieldNumber = 1;
-
-        /// <summary>Field number for the "latitude" field.</summary>
-        public const int LatitudeFieldNumber = 2;
-
-        /// <summary>Field number for the "longitude" field.</summary>
-        public const int LongitudeFieldNumber = 3;
-
-        private static readonly pb::MessageParser<FortDetailsRequest> _parser =
-            new pb::MessageParser<FortDetailsRequest>(() => new FortDetailsRequest());
-
-        private string fortId_ = "";
-        private double latitude_;
-        private double longitude_;
-
-        public FortDetailsRequest()
-        {
-            OnConstruction();
-        }
-
-        public FortDetailsRequest(FortDetailsRequest other) : this()
-        {
-            fortId_ = other.fortId_;
-            latitude_ = other.latitude_;
-            longitude_ = other.longitude_;
-        }
-
-        public static pb::MessageParser<FortDetailsRequest> Parser
-        {
-            get { return _parser; }
-        }
-
-        public static pbr::MessageDescriptor Descriptor
-        {
-            get { return global::PokemonGo.RocketAPI.GeneratedCode.PayloadsReflection.Descriptor.MessageTypes[53]; }
-        }
-
-        public string FortId
-        {
-            get { return fortId_; }
-            set { fortId_ = pb::ProtoPreconditions.CheckNotNull(value, "value"); }
-        }
-
-        public double Latitude
-        {
-            get { return latitude_; }
-            set { latitude_ = value; }
-        }
-
-        public double Longitude
-        {
-            get { return longitude_; }
-            set { longitude_ = value; }
-        }
-
-        pbr::MessageDescriptor pb::IMessage.Descriptor
-        {
-            get { return Descriptor; }
-        }
-
-        public FortDetailsRequest Clone()
-        {
-            return new FortDetailsRequest(this);
-        }
-
-        public bool Equals(FortDetailsRequest other)
-        {
-            if (ReferenceEquals(other, null))
-            {
-                return false;
-            }
-            if (ReferenceEquals(other, this))
-            {
-                return true;
-            }
-            if (FortId != other.FortId) return false;
-            if (Latitude != other.Latitude) return false;
-            if (Longitude != other.Longitude) return false;
-            return true;
-        }
-
-        public void WriteTo(pb::CodedOutputStream output)
-        {
-            if (FortId.Length != 0)
-            {
-                output.WriteRawTag(10);
-                output.WriteString(FortId);
-            }
-            if (Latitude != 0D)
-            {
-                output.WriteRawTag(17);
-                output.WriteDouble(Latitude);
-            }
-            if (Longitude != 0D)
-            {
-                output.WriteRawTag(25);
-                output.WriteDouble(Longitude);
-            }
-        }
-
-        public int CalculateSize()
-        {
-            var size = 0;
-            if (FortId.Length != 0)
-            {
-                size += 1 + pb::CodedOutputStream.ComputeStringSize(FortId);
-            }
-            if (Latitude != 0D)
-            {
-                size += 1 + 8;
-            }
-            if (Longitude != 0D)
-            {
-                size += 1 + 8;
-            }
-            return size;
-        }
-
-        public void MergeFrom(FortDetailsRequest other)
-        {
-            if (other == null)
-            {
-                return;
-            }
-            if (other.FortId.Length != 0)
-            {
-                FortId = other.FortId;
-            }
-            if (other.Latitude != 0D)
-            {
-                Latitude = other.Latitude;
-            }
-            if (other.Longitude != 0D)
-            {
-                Longitude = other.Longitude;
-            }
-        }
-
-        public void MergeFrom(pb::CodedInputStream input)
-        {
-            uint tag;
-            while ((tag = input.ReadTag()) != 0)
-            {
-                switch (tag)
-                {
-                    default:
-                        input.SkipLastField();
-                        break;
-                    case 10:
-                        {
-                            FortId = input.ReadString();
-                            break;
-                        }
-                    case 17:
-                        {
-                            Latitude = input.ReadDouble();
-                            break;
-                        }
-                    case 25:
-                        {
-                            Longitude = input.ReadDouble();
-                            break;
-                        }
-                }
-            }
-        }
-
-        public override bool Equals(object other)
-        {
-            return Equals(other as FortDetailsRequest);
-        }
-
-        public override int GetHashCode()
-        {
-            var hash = 1;
-            if (FortId.Length != 0) hash ^= FortId.GetHashCode();
-            if (Latitude != 0D) hash ^= Latitude.GetHashCode();
-            if (Longitude != 0D) hash ^= Longitude.GetHashCode();
-            return hash;
-        }
-
-        partial void OnConstruction();
-
-        public override string ToString()
-        {
-            return pb::JsonFormatter.ToDiagnosticString(this);
-        }
-    }
-
-    [global::System.Diagnostics.DebuggerNonUserCodeAttribute()]
-    public sealed partial class FortDetailsResponse : pb::IMessage<FortDetailsResponse>
-    {
-        /// <summary>Field number for the "fort_id" field.</summary>
-        public const int FortIdFieldNumber = 1;
-
-        /// <summary>Field number for the "team_color" field.</summary>
-        public const int TeamColorFieldNumber = 2;
-
-        /// <summary>Field number for the "pokemon_data" field.</summary>
-        public const int PokemonDataFieldNumber = 3;
-
-        /// <summary>Field number for the "name" field.</summary>
-        public const int NameFieldNumber = 4;
-
-        /// <summary>Field number for the "image_urls" field.</summary>
-        public const int ImageUrlsFieldNumber = 5;
-
-        /// <summary>Field number for the "fp" field.</summary>
-        public const int FpFieldNumber = 6;
-
-        /// <summary>Field number for the "stamina" field.</summary>
-        public const int StaminaFieldNumber = 7;
-
-        /// <summary>Field number for the "max_stamina" field.</summary>
-        public const int MaxStaminaFieldNumber = 8;
-
-        /// <summary>Field number for the "type" field.</summary>
-        public const int TypeFieldNumber = 9;
-
-        /// <summary>Field number for the "latitude" field.</summary>
-        public const int LatitudeFieldNumber = 10;
-
-        /// <summary>Field number for the "longitude" field.</summary>
-        public const int LongitudeFieldNumber = 11;
-
-        /// <summary>Field number for the "description" field.</summary>
-        public const int DescriptionFieldNumber = 12;
-
-        /// <summary>Field number for the "modifiers" field.</summary>
-        public const int ModifiersFieldNumber = 13;
-
-        private static readonly pb::MessageParser<FortDetailsResponse> _parser =
-            new pb::MessageParser<FortDetailsResponse>(() => new FortDetailsResponse());
-
-        private static readonly pb::FieldCodec<string> _repeated_imageUrls_codec
-            = pb::FieldCodec.ForString(42);
-
-        private static readonly pb::FieldCodec<global::PokemonGo.RocketAPI.GeneratedCode.FortModifier>
-            _repeated_modifiers_codec
-                = pb::FieldCodec.ForMessage(106, global::PokemonGo.RocketAPI.GeneratedCode.FortModifier.Parser);
-
-        private readonly pbc::RepeatedField<string> imageUrls_ = new pbc::RepeatedField<string>();
-
-        private readonly pbc::RepeatedField<global::PokemonGo.RocketAPI.GeneratedCode.FortModifier> modifiers_ =
-            new pbc::RepeatedField<global::PokemonGo.RocketAPI.GeneratedCode.FortModifier>();
-
-        private string description_ = "";
-        private string fortId_ = "";
-        private int fp_;
-        private double latitude_;
-        private double longitude_;
-        private int maxStamina_;
-        private string name_ = "";
-        private global::PokemonGo.RocketAPI.GeneratedCode.PokemonData pokemonData_;
-        private int stamina_;
-        private global::PokemonGo.RocketAPI.GeneratedCode.TeamColor teamColor_ = 0;
-        private global::PokemonGo.RocketAPI.GeneratedCode.FortType type_ = 0;
-
-        public FortDetailsResponse()
-        {
-            OnConstruction();
-        }
-
-        public FortDetailsResponse(FortDetailsResponse other) : this()
-        {
-            fortId_ = other.fortId_;
-            teamColor_ = other.teamColor_;
-            PokemonData = other.pokemonData_ != null ? other.PokemonData.Clone() : null;
-            name_ = other.name_;
-            imageUrls_ = other.imageUrls_.Clone();
-            fp_ = other.fp_;
-            stamina_ = other.stamina_;
-            maxStamina_ = other.maxStamina_;
-            type_ = other.type_;
-            latitude_ = other.latitude_;
-            longitude_ = other.longitude_;
-            description_ = other.description_;
-            modifiers_ = other.modifiers_.Clone();
-        }
-
-        public static pb::MessageParser<FortDetailsResponse> Parser
-        {
-            get { return _parser; }
-        }
-
-        public static pbr::MessageDescriptor Descriptor
-        {
-            get { return global::PokemonGo.RocketAPI.GeneratedCode.PayloadsReflection.Descriptor.MessageTypes[54]; }
-        }
-
-        public string FortId
-        {
-            get { return fortId_; }
-            set { fortId_ = pb::ProtoPreconditions.CheckNotNull(value, "value"); }
-        }
-
-        public global::PokemonGo.RocketAPI.GeneratedCode.TeamColor TeamColor
-        {
-            get { return teamColor_; }
-            set { teamColor_ = value; }
-        }
-
-        public global::PokemonGo.RocketAPI.GeneratedCode.PokemonData PokemonData
-        {
-            get { return pokemonData_; }
-            set { pokemonData_ = value; }
-        }
-
-        public string Name
-        {
-            get { return name_; }
-            set { name_ = pb::ProtoPreconditions.CheckNotNull(value, "value"); }
-        }
-
-        public pbc::RepeatedField<string> ImageUrls
-        {
-            get { return imageUrls_; }
-        }
-
-        public int Fp
-        {
-            get { return fp_; }
-            set { fp_ = value; }
-        }
-
-        public int Stamina
-        {
-            get { return stamina_; }
-            set { stamina_ = value; }
-        }
-
-        public int MaxStamina
-        {
-            get { return maxStamina_; }
-            set { maxStamina_ = value; }
-        }
-
-        public global::PokemonGo.RocketAPI.GeneratedCode.FortType Type
-        {
-            get { return type_; }
-            set { type_ = value; }
-        }
-
-        public double Latitude
-        {
-            get { return latitude_; }
-            set { latitude_ = value; }
-        }
-
-        public double Longitude
-        {
-            get { return longitude_; }
-            set { longitude_ = value; }
-        }
-
-        public string Description
-        {
-            get { return description_; }
-            set { description_ = pb::ProtoPreconditions.CheckNotNull(value, "value"); }
-        }
-
-        public pbc::RepeatedField<global::PokemonGo.RocketAPI.GeneratedCode.FortModifier> Modifiers
-        {
-            get { return modifiers_; }
-        }
-
-        pbr::MessageDescriptor pb::IMessage.Descriptor
-        {
-            get { return Descriptor; }
-        }
-
-        public FortDetailsResponse Clone()
-        {
-            return new FortDetailsResponse(this);
-        }
-
-        public bool Equals(FortDetailsResponse other)
-        {
-            if (ReferenceEquals(other, null))
-            {
-                return false;
-            }
-            if (ReferenceEquals(other, this))
-            {
-                return true;
-            }
-            if (FortId != other.FortId) return false;
-            if (TeamColor != other.TeamColor) return false;
-            if (!Equals(PokemonData, other.PokemonData)) return false;
-            if (Name != other.Name) return false;
-            if (!imageUrls_.Equals(other.imageUrls_)) return false;
-            if (Fp != other.Fp) return false;
-            if (Stamina != other.Stamina) return false;
-            if (MaxStamina != other.MaxStamina) return false;
-            if (Type != other.Type) return false;
-            if (Latitude != other.Latitude) return false;
-            if (Longitude != other.Longitude) return false;
-            if (Description != other.Description) return false;
-            if (!modifiers_.Equals(other.modifiers_)) return false;
-            return true;
-        }
-
-        public void WriteTo(pb::CodedOutputStream output)
-        {
-            if (FortId.Length != 0)
-            {
-                output.WriteRawTag(10);
-                output.WriteString(FortId);
-            }
-            if (TeamColor != 0)
-            {
-                output.WriteRawTag(16);
-                output.WriteEnum((int)TeamColor);
-            }
-            if (pokemonData_ != null)
-            {
-                output.WriteRawTag(26);
-                output.WriteMessage(PokemonData);
-            }
-            if (Name.Length != 0)
-            {
-                output.WriteRawTag(34);
-                output.WriteString(Name);
-            }
-            imageUrls_.WriteTo(output, _repeated_imageUrls_codec);
-            if (Fp != 0)
-            {
-                output.WriteRawTag(48);
-                output.WriteInt32(Fp);
-            }
-            if (Stamina != 0)
-            {
-                output.WriteRawTag(56);
-                output.WriteInt32(Stamina);
-            }
-            if (MaxStamina != 0)
-            {
-                output.WriteRawTag(64);
-                output.WriteInt32(MaxStamina);
-            }
-            if (Type != 0)
-            {
-                output.WriteRawTag(72);
-                output.WriteEnum((int)Type);
-            }
-            if (Latitude != 0D)
-            {
-                output.WriteRawTag(81);
-                output.WriteDouble(Latitude);
-            }
-            if (Longitude != 0D)
-            {
-                output.WriteRawTag(89);
-                output.WriteDouble(Longitude);
-            }
-            if (Description.Length != 0)
-            {
-                output.WriteRawTag(98);
-                output.WriteString(Description);
-            }
-            modifiers_.WriteTo(output, _repeated_modifiers_codec);
-        }
-
-        public int CalculateSize()
-        {
-            var size = 0;
-            if (FortId.Length != 0)
-            {
-                size += 1 + pb::CodedOutputStream.ComputeStringSize(FortId);
-            }
-            if (TeamColor != 0)
-            {
-                size += 1 + pb::CodedOutputStream.ComputeEnumSize((int)TeamColor);
-            }
-            if (pokemonData_ != null)
-            {
-                size += 1 + pb::CodedOutputStream.ComputeMessageSize(PokemonData);
-            }
-            if (Name.Length != 0)
-            {
-                size += 1 + pb::CodedOutputStream.ComputeStringSize(Name);
-            }
-            size += imageUrls_.CalculateSize(_repeated_imageUrls_codec);
-            if (Fp != 0)
-            {
-                size += 1 + pb::CodedOutputStream.ComputeInt32Size(Fp);
-            }
-            if (Stamina != 0)
-            {
-                size += 1 + pb::CodedOutputStream.ComputeInt32Size(Stamina);
-            }
-            if (MaxStamina != 0)
-            {
-                size += 1 + pb::CodedOutputStream.ComputeInt32Size(MaxStamina);
-            }
-            if (Type != 0)
-            {
-                size += 1 + pb::CodedOutputStream.ComputeEnumSize((int)Type);
-            }
-            if (Latitude != 0D)
-            {
-                size += 1 + 8;
-            }
-            if (Longitude != 0D)
-            {
-                size += 1 + 8;
-            }
-            if (Description.Length != 0)
-            {
-                size += 1 + pb::CodedOutputStream.ComputeStringSize(Description);
-            }
-            size += modifiers_.CalculateSize(_repeated_modifiers_codec);
-            return size;
-        }
-
-        public void MergeFrom(FortDetailsResponse other)
-        {
-            if (other == null)
-            {
-                return;
-            }
-            if (other.FortId.Length != 0)
-            {
-                FortId = other.FortId;
-            }
-            if (other.TeamColor != 0)
-            {
-                TeamColor = other.TeamColor;
-            }
-            if (other.pokemonData_ != null)
-            {
-                if (pokemonData_ == null)
-                {
-                    pokemonData_ = new global::PokemonGo.RocketAPI.GeneratedCode.PokemonData();
-                }
-                PokemonData.MergeFrom(other.PokemonData);
-            }
-            if (other.Name.Length != 0)
-            {
-                Name = other.Name;
-            }
-            imageUrls_.Add(other.imageUrls_);
-            if (other.Fp != 0)
-            {
-                Fp = other.Fp;
-            }
-            if (other.Stamina != 0)
-            {
-                Stamina = other.Stamina;
-            }
-            if (other.MaxStamina != 0)
-            {
-                MaxStamina = other.MaxStamina;
-            }
-            if (other.Type != 0)
-            {
-                Type = other.Type;
-            }
-            if (other.Latitude != 0D)
-            {
-                Latitude = other.Latitude;
-            }
-            if (other.Longitude != 0D)
-            {
-                Longitude = other.Longitude;
-            }
-            if (other.Description.Length != 0)
-            {
-                Description = other.Description;
-            }
-            modifiers_.Add(other.modifiers_);
-        }
-
-        public void MergeFrom(pb::CodedInputStream input)
-        {
-            uint tag;
-            while ((tag = input.ReadTag()) != 0)
-            {
-                switch (tag)
-                {
-                    default:
-                        input.SkipLastField();
-                        break;
-                    case 10:
-                        {
-                            FortId = input.ReadString();
-                            break;
-                        }
-                    case 16:
-                        {
-                            teamColor_ = (global::PokemonGo.RocketAPI.GeneratedCode.TeamColor)input.ReadEnum();
-                            break;
-                        }
-                    case 26:
-                        {
-                            if (pokemonData_ == null)
-                            {
-                                pokemonData_ = new global::PokemonGo.RocketAPI.GeneratedCode.PokemonData();
-                            }
-                            input.ReadMessage(pokemonData_);
-                            break;
-                        }
-                    case 34:
-                        {
-                            Name = input.ReadString();
-                            break;
-                        }
-                    case 42:
-                        {
-                            imageUrls_.AddEntriesFrom(input, _repeated_imageUrls_codec);
-                            break;
-                        }
-                    case 48:
-                        {
-                            Fp = input.ReadInt32();
-                            break;
-                        }
-                    case 56:
-                        {
-                            Stamina = input.ReadInt32();
-                            break;
-                        }
-                    case 64:
-                        {
-                            MaxStamina = input.ReadInt32();
-                            break;
-                        }
-                    case 72:
-                        {
-                            type_ = (global::PokemonGo.RocketAPI.GeneratedCode.FortType)input.ReadEnum();
-                            break;
-                        }
-                    case 81:
-                        {
-                            Latitude = input.ReadDouble();
-                            break;
-                        }
-                    case 89:
-                        {
-                            Longitude = input.ReadDouble();
-                            break;
-                        }
-                    case 98:
-                        {
-                            Description = input.ReadString();
-                            break;
-                        }
-                    case 106:
-                        {
-                            modifiers_.AddEntriesFrom(input, _repeated_modifiers_codec);
-                            break;
-                        }
-                }
-            }
-        }
-
-        public override bool Equals(object other)
-        {
-            return Equals(other as FortDetailsResponse);
-        }
-
-        public override int GetHashCode()
-        {
-            var hash = 1;
-            if (FortId.Length != 0) hash ^= FortId.GetHashCode();
-            if (TeamColor != 0) hash ^= TeamColor.GetHashCode();
-            if (pokemonData_ != null) hash ^= PokemonData.GetHashCode();
-            if (Name.Length != 0) hash ^= Name.GetHashCode();
-            hash ^= imageUrls_.GetHashCode();
-            if (Fp != 0) hash ^= Fp.GetHashCode();
-            if (Stamina != 0) hash ^= Stamina.GetHashCode();
-            if (MaxStamina != 0) hash ^= MaxStamina.GetHashCode();
-            if (Type != 0) hash ^= Type.GetHashCode();
-            if (Latitude != 0D) hash ^= Latitude.GetHashCode();
-            if (Longitude != 0D) hash ^= Longitude.GetHashCode();
-            if (Description.Length != 0) hash ^= Description.GetHashCode();
-            hash ^= modifiers_.GetHashCode();
-            return hash;
-        }
-
-        partial void OnConstruction();
-
-        public override string ToString()
-        {
-            return pb::JsonFormatter.ToDiagnosticString(this);
-        }
-    }
-
-    [global::System.Diagnostics.DebuggerNonUserCodeAttribute()]
-    public sealed partial class FortModifier : pb::IMessage<FortModifier>
-    {
-        /// <summary>Field number for the "item_id" field.</summary>
-        public const int ItemIdFieldNumber = 1;
-
-        /// <summary>Field number for the "expiration_timestamp_ms" field.</summary>
-        public const int ExpirationTimestampMsFieldNumber = 2;
-
-        /// <summary>Field number for the "deployer_player_codename" field.</summary>
-        public const int DeployerPlayerCodenameFieldNumber = 3;
-
-        private static readonly pb::MessageParser<FortModifier> _parser =
-            new pb::MessageParser<FortModifier>(() => new FortModifier());
-
-        private string deployerPlayerCodename_ = "";
-        private long expirationTimestampMs_;
-        private global::PokemonGo.RocketAPI.GeneratedCode.ItemId itemId_ = 0;
-
-        public FortModifier()
-        {
-            OnConstruction();
-        }
-
-        public FortModifier(FortModifier other) : this()
-        {
-            itemId_ = other.itemId_;
-            expirationTimestampMs_ = other.expirationTimestampMs_;
-            deployerPlayerCodename_ = other.deployerPlayerCodename_;
-        }
-
-        public static pb::MessageParser<FortModifier> Parser
-        {
-            get { return _parser; }
-        }
-
-        public static pbr::MessageDescriptor Descriptor
-        {
-            get { return global::PokemonGo.RocketAPI.GeneratedCode.PayloadsReflection.Descriptor.MessageTypes[55]; }
-        }
-
-        public global::PokemonGo.RocketAPI.GeneratedCode.ItemId ItemId
-        {
-            get { return itemId_; }
-            set { itemId_ = value; }
-        }
-
-        public long ExpirationTimestampMs
-        {
-            get { return expirationTimestampMs_; }
-            set { expirationTimestampMs_ = value; }
-        }
-
-        public string DeployerPlayerCodename
-        {
-            get { return deployerPlayerCodename_; }
-            set { deployerPlayerCodename_ = pb::ProtoPreconditions.CheckNotNull(value, "value"); }
-        }
-
-        pbr::MessageDescriptor pb::IMessage.Descriptor
-        {
-            get { return Descriptor; }
-        }
-
-        public FortModifier Clone()
-        {
-            return new FortModifier(this);
-        }
-
-        public bool Equals(FortModifier other)
-        {
-            if (ReferenceEquals(other, null))
-            {
-                return false;
-            }
-            if (ReferenceEquals(other, this))
-            {
-                return true;
-            }
-            if (ItemId != other.ItemId) return false;
-            if (ExpirationTimestampMs != other.ExpirationTimestampMs) return false;
-            if (DeployerPlayerCodename != other.DeployerPlayerCodename) return false;
-            return true;
-        }
-
-        public void WriteTo(pb::CodedOutputStream output)
-        {
-            if (ItemId != 0)
-            {
-                output.WriteRawTag(8);
-                output.WriteEnum((int)ItemId);
-            }
-            if (ExpirationTimestampMs != 0L)
-            {
-                output.WriteRawTag(16);
-                output.WriteInt64(ExpirationTimestampMs);
-            }
-            if (DeployerPlayerCodename.Length != 0)
-            {
-                output.WriteRawTag(26);
-                output.WriteString(DeployerPlayerCodename);
-            }
-        }
-
-        public int CalculateSize()
-        {
-            var size = 0;
-            if (ItemId != 0)
-            {
-                size += 1 + pb::CodedOutputStream.ComputeEnumSize((int)ItemId);
-            }
-            if (ExpirationTimestampMs != 0L)
-            {
-                size += 1 + pb::CodedOutputStream.ComputeInt64Size(ExpirationTimestampMs);
-            }
-            if (DeployerPlayerCodename.Length != 0)
-            {
-                size += 1 + pb::CodedOutputStream.ComputeStringSize(DeployerPlayerCodename);
-            }
-            return size;
-        }
-
-        public void MergeFrom(FortModifier other)
-        {
-            if (other == null)
-            {
-                return;
-            }
-            if (other.ItemId != 0)
-            {
-                ItemId = other.ItemId;
-            }
-            if (other.ExpirationTimestampMs != 0L)
-            {
-                ExpirationTimestampMs = other.ExpirationTimestampMs;
-            }
-            if (other.DeployerPlayerCodename.Length != 0)
-            {
-                DeployerPlayerCodename = other.DeployerPlayerCodename;
-            }
-        }
-
-        public void MergeFrom(pb::CodedInputStream input)
-        {
-            uint tag;
-            while ((tag = input.ReadTag()) != 0)
-            {
-                switch (tag)
-                {
-                    default:
-                        input.SkipLastField();
-                        break;
-                    case 8:
-                        {
-                            itemId_ = (global::PokemonGo.RocketAPI.GeneratedCode.ItemId)input.ReadEnum();
-                            break;
-                        }
-                    case 16:
-                        {
-                            ExpirationTimestampMs = input.ReadInt64();
-                            break;
-                        }
-                    case 26:
-                        {
-                            DeployerPlayerCodename = input.ReadString();
-                            break;
-                        }
-                }
-            }
-        }
-
-        public override bool Equals(object other)
-        {
-            return Equals(other as FortModifier);
-        }
-
-        public override int GetHashCode()
-        {
-            var hash = 1;
-            if (ItemId != 0) hash ^= ItemId.GetHashCode();
-            if (ExpirationTimestampMs != 0L) hash ^= ExpirationTimestampMs.GetHashCode();
-            if (DeployerPlayerCodename.Length != 0) hash ^= DeployerPlayerCodename.GetHashCode();
-            return hash;
-        }
-
-        partial void OnConstruction();
-
-        public override string ToString()
-        {
-            return pb::JsonFormatter.ToDiagnosticString(this);
-        }
-    }
-
-    [global::System.Diagnostics.DebuggerNonUserCodeAttribute()]
-    public sealed partial class EncounterRequest : pb::IMessage<EncounterRequest>
-    {
-        /// <summary>Field number for the "encounter_id" field.</summary>
-        public const int EncounterIdFieldNumber = 1;
-
-        /// <summary>Field number for the "spawnpoint_id" field.</summary>
-        public const int SpawnpointIdFieldNumber = 2;
-
-        /// <summary>Field number for the "player_latitude" field.</summary>
-        public const int PlayerLatitudeFieldNumber = 3;
-
-        /// <summary>Field number for the "player_longitude" field.</summary>
-        public const int PlayerLongitudeFieldNumber = 4;
-
-        private static readonly pb::MessageParser<EncounterRequest> _parser =
-            new pb::MessageParser<EncounterRequest>(() => new EncounterRequest());
-
-        private ulong encounterId_;
-        private double playerLatitude_;
-        private double playerLongitude_;
-        private string spawnpointId_ = "";
-
-        public EncounterRequest()
-        {
-            OnConstruction();
-        }
-
-        public EncounterRequest(EncounterRequest other) : this()
-        {
-            encounterId_ = other.encounterId_;
-            spawnpointId_ = other.spawnpointId_;
-            playerLatitude_ = other.playerLatitude_;
-            playerLongitude_ = other.playerLongitude_;
-        }
-
-        public static pb::MessageParser<EncounterRequest> Parser
-        {
-            get { return _parser; }
-        }
-
-        public static pbr::MessageDescriptor Descriptor
-        {
-            get { return global::PokemonGo.RocketAPI.GeneratedCode.PayloadsReflection.Descriptor.MessageTypes[56]; }
-        }
-
-        public ulong EncounterId
-        {
-            get { return encounterId_; }
-            set { encounterId_ = value; }
-        }
-
-        public string SpawnpointId
-        {
-            get { return spawnpointId_; }
-            set { spawnpointId_ = pb::ProtoPreconditions.CheckNotNull(value, "value"); }
-        }
-
-        public double PlayerLatitude
-        {
-            get { return playerLatitude_; }
-            set { playerLatitude_ = value; }
-        }
-
-        public double PlayerLongitude
-        {
-            get { return playerLongitude_; }
-            set { playerLongitude_ = value; }
-        }
-
-        pbr::MessageDescriptor pb::IMessage.Descriptor
-        {
-            get { return Descriptor; }
-        }
-
-        public EncounterRequest Clone()
-        {
-            return new EncounterRequest(this);
-        }
-
-        public bool Equals(EncounterRequest other)
-        {
-            if (ReferenceEquals(other, null))
-            {
-                return false;
-            }
-            if (ReferenceEquals(other, this))
-            {
-                return true;
-            }
-            if (EncounterId != other.EncounterId) return false;
-            if (SpawnpointId != other.SpawnpointId) return false;
-            if (PlayerLatitude != other.PlayerLatitude) return false;
-            if (PlayerLongitude != other.PlayerLongitude) return false;
-            return true;
-        }
-
-        public void WriteTo(pb::CodedOutputStream output)
-        {
-            if (EncounterId != 0UL)
-            {
-                output.WriteRawTag(9);
-                output.WriteFixed64(EncounterId);
-            }
-            if (SpawnpointId.Length != 0)
-            {
-                output.WriteRawTag(18);
-                output.WriteString(SpawnpointId);
-            }
-            if (PlayerLatitude != 0D)
-            {
-                output.WriteRawTag(25);
-                output.WriteDouble(PlayerLatitude);
-            }
-            if (PlayerLongitude != 0D)
-            {
-                output.WriteRawTag(33);
-                output.WriteDouble(PlayerLongitude);
-            }
-        }
-
-        public int CalculateSize()
-        {
-            var size = 0;
-            if (EncounterId != 0UL)
-            {
-                size += 1 + 8;
-            }
-            if (SpawnpointId.Length != 0)
-            {
-                size += 1 + pb::CodedOutputStream.ComputeStringSize(SpawnpointId);
-            }
-            if (PlayerLatitude != 0D)
-            {
-                size += 1 + 8;
-            }
-            if (PlayerLongitude != 0D)
-            {
-                size += 1 + 8;
-            }
-            return size;
-        }
-
-        public void MergeFrom(EncounterRequest other)
-        {
-            if (other == null)
-            {
-                return;
-            }
-            if (other.EncounterId != 0UL)
-            {
-                EncounterId = other.EncounterId;
-            }
-            if (other.SpawnpointId.Length != 0)
-            {
-                SpawnpointId = other.SpawnpointId;
-            }
-            if (other.PlayerLatitude != 0D)
-            {
-                PlayerLatitude = other.PlayerLatitude;
-            }
-            if (other.PlayerLongitude != 0D)
-            {
-                PlayerLongitude = other.PlayerLongitude;
-            }
-        }
-
-        public void MergeFrom(pb::CodedInputStream input)
-        {
-            uint tag;
-            while ((tag = input.ReadTag()) != 0)
-            {
-                switch (tag)
-                {
-                    default:
-                        input.SkipLastField();
-                        break;
-                    case 9:
-                        {
-                            EncounterId = input.ReadFixed64();
-                            break;
-                        }
-                    case 18:
-                        {
-                            SpawnpointId = input.ReadString();
-                            break;
-                        }
-                    case 25:
-                        {
-                            PlayerLatitude = input.ReadDouble();
-                            break;
-                        }
-                    case 33:
-                        {
-                            PlayerLongitude = input.ReadDouble();
-                            break;
-                        }
-                }
-            }
-        }
-
-        public override bool Equals(object other)
-        {
-            return Equals(other as EncounterRequest);
-        }
-
-        public override int GetHashCode()
-        {
-            var hash = 1;
-            if (EncounterId != 0UL) hash ^= EncounterId.GetHashCode();
-            if (SpawnpointId.Length != 0) hash ^= SpawnpointId.GetHashCode();
-            if (PlayerLatitude != 0D) hash ^= PlayerLatitude.GetHashCode();
-            if (PlayerLongitude != 0D) hash ^= PlayerLongitude.GetHashCode();
-            return hash;
-        }
-
-        partial void OnConstruction();
-
-        public override string ToString()
-        {
-            return pb::JsonFormatter.ToDiagnosticString(this);
-        }
-    }
-
-    [global::System.Diagnostics.DebuggerNonUserCodeAttribute()]
-    public sealed partial class EncounterResponse : pb::IMessage<EncounterResponse>
-    {
-        /// <summary>Field number for the "wild_pokemon" field.</summary>
-        public const int WildPokemonFieldNumber = 1;
-
-        /// <summary>Field number for the "background" field.</summary>
-        public const int BackgroundFieldNumber = 2;
-
-        /// <summary>Field number for the "status" field.</summary>
-        public const int StatusFieldNumber = 3;
-
-        /// <summary>Field number for the "capture_probability" field.</summary>
-        public const int CaptureProbabilityFieldNumber = 4;
-
-        private static readonly pb::MessageParser<EncounterResponse> _parser =
-            new pb::MessageParser<EncounterResponse>(() => new EncounterResponse());
-
-        private global::PokemonGo.RocketAPI.GeneratedCode.EncounterResponse.Types.Background background_ = 0;
-        private global::PokemonGo.RocketAPI.GeneratedCode.CaptureProbability captureProbability_;
-        private global::PokemonGo.RocketAPI.GeneratedCode.EncounterResponse.Types.Status status_ = 0;
-        private global::PokemonGo.RocketAPI.GeneratedCode.WildPokemon wildPokemon_;
-
-        public EncounterResponse()
-        {
-            OnConstruction();
-        }
-
-        public EncounterResponse(EncounterResponse other) : this()
-        {
-            WildPokemon = other.wildPokemon_ != null ? other.WildPokemon.Clone() : null;
-            background_ = other.background_;
-            status_ = other.status_;
-            CaptureProbability = other.captureProbability_ != null ? other.CaptureProbability.Clone() : null;
-        }
-
-        public static pb::MessageParser<EncounterResponse> Parser
-        {
-            get { return _parser; }
-        }
-
-        public static pbr::MessageDescriptor Descriptor
-        {
-            get { return global::PokemonGo.RocketAPI.GeneratedCode.PayloadsReflection.Descriptor.MessageTypes[57]; }
-        }
-
-        public global::PokemonGo.RocketAPI.GeneratedCode.WildPokemon WildPokemon
-        {
-            get { return wildPokemon_; }
-            set { wildPokemon_ = value; }
-        }
-
-        public global::PokemonGo.RocketAPI.GeneratedCode.EncounterResponse.Types.Background Background
-        {
-            get { return background_; }
-            set { background_ = value; }
-        }
-
-        public global::PokemonGo.RocketAPI.GeneratedCode.EncounterResponse.Types.Status Status
-        {
-            get { return status_; }
-            set { status_ = value; }
-        }
-
-        public global::PokemonGo.RocketAPI.GeneratedCode.CaptureProbability CaptureProbability
-        {
-            get { return captureProbability_; }
-            set { captureProbability_ = value; }
-        }
-
-        pbr::MessageDescriptor pb::IMessage.Descriptor
-        {
-            get { return Descriptor; }
-        }
-
-        public EncounterResponse Clone()
-        {
-            return new EncounterResponse(this);
-        }
-
-        public bool Equals(EncounterResponse other)
-        {
-            if (ReferenceEquals(other, null))
-            {
-                return false;
-            }
-            if (ReferenceEquals(other, this))
-            {
-                return true;
-            }
-            if (!Equals(WildPokemon, other.WildPokemon)) return false;
-            if (Background != other.Background) return false;
-            if (Status != other.Status) return false;
-            if (!Equals(CaptureProbability, other.CaptureProbability)) return false;
-            return true;
-        }
-
-        public void WriteTo(pb::CodedOutputStream output)
-        {
-            if (wildPokemon_ != null)
-            {
-                output.WriteRawTag(10);
-                output.WriteMessage(WildPokemon);
-            }
-            if (Background != 0)
-            {
-                output.WriteRawTag(16);
-                output.WriteEnum((int)Background);
-            }
-            if (Status != 0)
-            {
-                output.WriteRawTag(24);
-                output.WriteEnum((int)Status);
-            }
-            if (captureProbability_ != null)
-            {
-                output.WriteRawTag(34);
-                output.WriteMessage(CaptureProbability);
-            }
-        }
-
-        public int CalculateSize()
-        {
-            var size = 0;
-            if (wildPokemon_ != null)
-            {
-                size += 1 + pb::CodedOutputStream.ComputeMessageSize(WildPokemon);
-            }
-            if (Background != 0)
-            {
-                size += 1 + pb::CodedOutputStream.ComputeEnumSize((int)Background);
-            }
-            if (Status != 0)
-            {
-                size += 1 + pb::CodedOutputStream.ComputeEnumSize((int)Status);
-            }
-            if (captureProbability_ != null)
-            {
-                size += 1 + pb::CodedOutputStream.ComputeMessageSize(CaptureProbability);
-            }
-            return size;
-        }
-
-        public void MergeFrom(EncounterResponse other)
-        {
-            if (other == null)
-            {
-                return;
-            }
-            if (other.wildPokemon_ != null)
-            {
-                if (wildPokemon_ == null)
-                {
-                    wildPokemon_ = new global::PokemonGo.RocketAPI.GeneratedCode.WildPokemon();
-                }
-                WildPokemon.MergeFrom(other.WildPokemon);
-            }
-            if (other.Background != 0)
-            {
-                Background = other.Background;
-            }
-            if (other.Status != 0)
-            {
-                Status = other.Status;
-            }
-            if (other.captureProbability_ != null)
-            {
-                if (captureProbability_ == null)
-                {
-                    captureProbability_ = new global::PokemonGo.RocketAPI.GeneratedCode.CaptureProbability();
-                }
-                CaptureProbability.MergeFrom(other.CaptureProbability);
-            }
-        }
-
-        public void MergeFrom(pb::CodedInputStream input)
-        {
-            uint tag;
-            while ((tag = input.ReadTag()) != 0)
-            {
-                switch (tag)
-                {
-                    default:
-                        input.SkipLastField();
-                        break;
-                    case 10:
-                        {
-                            if (wildPokemon_ == null)
-                            {
-                                wildPokemon_ = new global::PokemonGo.RocketAPI.GeneratedCode.WildPokemon();
-                            }
-                            input.ReadMessage(wildPokemon_);
-                            break;
-                        }
-                    case 16:
-                        {
-                            background_ =
-                                (global::PokemonGo.RocketAPI.GeneratedCode.EncounterResponse.Types.Background)
-                                    input.ReadEnum();
-                            break;
-                        }
-                    case 24:
-                        {
-                            status_ =
-                                (global::PokemonGo.RocketAPI.GeneratedCode.EncounterResponse.Types.Status)input.ReadEnum();
-                            break;
-                        }
-                    case 34:
-                        {
-                            if (captureProbability_ == null)
-                            {
-                                captureProbability_ = new global::PokemonGo.RocketAPI.GeneratedCode.CaptureProbability();
-                            }
-                            input.ReadMessage(captureProbability_);
-                            break;
-                        }
-                }
-            }
-        }
-
-        public override bool Equals(object other)
-        {
-            return Equals(other as EncounterResponse);
-        }
-
-        public override int GetHashCode()
-        {
-            var hash = 1;
-            if (wildPokemon_ != null) hash ^= WildPokemon.GetHashCode();
-            if (Background != 0) hash ^= Background.GetHashCode();
-            if (Status != 0) hash ^= Status.GetHashCode();
-            if (captureProbability_ != null) hash ^= CaptureProbability.GetHashCode();
-            return hash;
-        }
-
-        partial void OnConstruction();
-
-        public override string ToString()
-        {
-            return pb::JsonFormatter.ToDiagnosticString(this);
-        }
-
-        #region Nested types
-
-        /// <summary>Container for nested types declared in the EncounterResponse message type.</summary>
-        [global::System.Diagnostics.DebuggerNonUserCodeAttribute()]
-        public static partial class Types
-        {
-            public enum Background
-            {
-                [pbr::OriginalName("PARK")]
-                Park = 0,
-                [pbr::OriginalName("DESERT")]
-                Desert = 1,
-            }
-
-            public enum Status
-            {
-                [pbr::OriginalName("ENCOUNTER_ERROR")]
-                EncounterError = 0,
-                [pbr::OriginalName("ENCOUNTER_SUCCESS")]
-                EncounterSuccess = 1,
-                [pbr::OriginalName("ENCOUNTER_NOT_FOUND")]
-                EncounterNotFound = 2,
-                [pbr::OriginalName("ENCOUNTER_CLOSED")]
-                EncounterClosed = 3,
-                [pbr::OriginalName("ENCOUNTER_POKEMON_FLED")]
-                EncounterPokemonFled = 4,
-                [pbr::OriginalName("ENCOUNTER_NOT_IN_RANGE")]
-                EncounterNotInRange = 5,
-                [pbr::OriginalName("ENCOUNTER_ALREADY_HAPPENED")]
-                EncounterAlreadyHappened = 6,
-                [pbr::OriginalName("POKEMON_INVENTORY_FULL")]
-                PokemonInventoryFull = 7,
-            }
-        }
-
-        #endregion
-    }
-
-    [global::System.Diagnostics.DebuggerNonUserCodeAttribute()]
-    public sealed partial class CaptureProbability : pb::IMessage<CaptureProbability>
-    {
-        /// <summary>Field number for the "pokeball_type" field.</summary>
-        public const int PokeballTypeFieldNumber = 1;
-
-        /// <summary>Field number for the "capture_probability" field.</summary>
-        public const int CaptureProbability_FieldNumber = 2;
-
-        /// <summary>Field number for the "reticle_difficulty_scale" field.</summary>
-        public const int ReticleDifficultyScaleFieldNumber = 12;
-
-        private static readonly pb::MessageParser<CaptureProbability> _parser =
-            new pb::MessageParser<CaptureProbability>(() => new CaptureProbability());
-
-        private static readonly pb::FieldCodec<global::PokemonGo.RocketAPI.GeneratedCode.ItemId>
-            _repeated_pokeballType_codec
-                = pb::FieldCodec.ForEnum(10, x => (int)x, x => (global::PokemonGo.RocketAPI.GeneratedCode.ItemId)x);
-
-        private static readonly pb::FieldCodec<float> _repeated_captureProbability_codec
-            = pb::FieldCodec.ForFloat(18);
-
-        private readonly pbc::RepeatedField<float> captureProbability_ = new pbc::RepeatedField<float>();
-
-        private readonly pbc::RepeatedField<global::PokemonGo.RocketAPI.GeneratedCode.ItemId> pokeballType_ =
-            new pbc::RepeatedField<global::PokemonGo.RocketAPI.GeneratedCode.ItemId>();
-
-        private double reticleDifficultyScale_;
-
-        public CaptureProbability()
-        {
-            OnConstruction();
-        }
-
-        public CaptureProbability(CaptureProbability other) : this()
-        {
-            pokeballType_ = other.pokeballType_.Clone();
-            captureProbability_ = other.captureProbability_.Clone();
-            reticleDifficultyScale_ = other.reticleDifficultyScale_;
-        }
-
-        public static pb::MessageParser<CaptureProbability> Parser
-        {
-            get { return _parser; }
-        }
-
-        public static pbr::MessageDescriptor Descriptor
-        {
-            get { return global::PokemonGo.RocketAPI.GeneratedCode.PayloadsReflection.Descriptor.MessageTypes[58]; }
-        }
-
-        public pbc::RepeatedField<global::PokemonGo.RocketAPI.GeneratedCode.ItemId> PokeballType
-        {
-            get { return pokeballType_; }
-        }
-
-        public pbc::RepeatedField<float> CaptureProbability_
-        {
-            get { return captureProbability_; }
-        }
-
-        public double ReticleDifficultyScale
-        {
-            get { return reticleDifficultyScale_; }
-            set { reticleDifficultyScale_ = value; }
-        }
-
-        pbr::MessageDescriptor pb::IMessage.Descriptor
-        {
-            get { return Descriptor; }
-        }
-
-        public CaptureProbability Clone()
-        {
-            return new CaptureProbability(this);
-        }
-
-        public bool Equals(CaptureProbability other)
-        {
-            if (ReferenceEquals(other, null))
-            {
-                return false;
-            }
-            if (ReferenceEquals(other, this))
-            {
-                return true;
-            }
-            if (!pokeballType_.Equals(other.pokeballType_)) return false;
-            if (!captureProbability_.Equals(other.captureProbability_)) return false;
-            if (ReticleDifficultyScale != other.ReticleDifficultyScale) return false;
-            return true;
-        }
-
-        public void WriteTo(pb::CodedOutputStream output)
-        {
-            pokeballType_.WriteTo(output, _repeated_pokeballType_codec);
-            captureProbability_.WriteTo(output, _repeated_captureProbability_codec);
-            if (ReticleDifficultyScale != 0D)
-            {
-                output.WriteRawTag(97);
-                output.WriteDouble(ReticleDifficultyScale);
-            }
-        }
-
-        public int CalculateSize()
-        {
-            var size = 0;
-            size += pokeballType_.CalculateSize(_repeated_pokeballType_codec);
-            size += captureProbability_.CalculateSize(_repeated_captureProbability_codec);
-            if (ReticleDifficultyScale != 0D)
-            {
-                size += 1 + 8;
-            }
-            return size;
-        }
-
-        public void MergeFrom(CaptureProbability other)
-        {
-            if (other == null)
-            {
-                return;
-            }
-            pokeballType_.Add(other.pokeballType_);
-            captureProbability_.Add(other.captureProbability_);
-            if (other.ReticleDifficultyScale != 0D)
-            {
-                ReticleDifficultyScale = other.ReticleDifficultyScale;
-            }
-        }
-
-        public void MergeFrom(pb::CodedInputStream input)
-        {
-            uint tag;
-            while ((tag = input.ReadTag()) != 0)
-            {
-                switch (tag)
-                {
-                    default:
-                        input.SkipLastField();
-                        break;
-                    case 10:
-                    case 8:
-                        {
-                            pokeballType_.AddEntriesFrom(input, _repeated_pokeballType_codec);
-                            break;
-                        }
-                    case 18:
-                    case 21:
-                        {
-                            captureProbability_.AddEntriesFrom(input, _repeated_captureProbability_codec);
-                            break;
-                        }
-                    case 97:
-                        {
-                            ReticleDifficultyScale = input.ReadDouble();
-                            break;
-                        }
-                }
-            }
-        }
-
-        public override bool Equals(object other)
-        {
-            return Equals(other as CaptureProbability);
-        }
-
-        public override int GetHashCode()
-        {
-            var hash = 1;
-            hash ^= pokeballType_.GetHashCode();
-            hash ^= captureProbability_.GetHashCode();
-            if (ReticleDifficultyScale != 0D) hash ^= ReticleDifficultyScale.GetHashCode();
-            return hash;
-        }
-
-        partial void OnConstruction();
-
-        public override string ToString()
-        {
-            return pb::JsonFormatter.ToDiagnosticString(this);
-        }
-    }
-
-    [global::System.Diagnostics.DebuggerNonUserCodeAttribute()]
-    public sealed partial class DiskEncounterRequest : pb::IMessage<DiskEncounterRequest>
-    {
-        /// <summary>Field number for the "encounter_id" field.</summary>
-        public const int EncounterIdFieldNumber = 1;
-
-        /// <summary>Field number for the "fort_id" field.</summary>
-        public const int FortIdFieldNumber = 2;
-
-        /// <summary>Field number for the "player_latitude" field.</summary>
-        public const int PlayerLatitudeFieldNumber = 3;
-
-        /// <summary>Field number for the "player_longitude" field.</summary>
-        public const int PlayerLongitudeFieldNumber = 4;
-
-        private static readonly pb::MessageParser<DiskEncounterRequest> _parser =
-            new pb::MessageParser<DiskEncounterRequest>(() => new DiskEncounterRequest());
-
-        private ulong encounterId_;
-        private string fortId_ = "";
-        private double playerLatitude_;
-        private double playerLongitude_;
-
-        public DiskEncounterRequest()
-        {
-            OnConstruction();
-        }
-
-        public DiskEncounterRequest(DiskEncounterRequest other) : this()
-        {
-            encounterId_ = other.encounterId_;
-            fortId_ = other.fortId_;
-            playerLatitude_ = other.playerLatitude_;
-            playerLongitude_ = other.playerLongitude_;
-        }
-
-        public static pb::MessageParser<DiskEncounterRequest> Parser
-        {
-            get { return _parser; }
-        }
-
-        public static pbr::MessageDescriptor Descriptor
-        {
-            get { return global::PokemonGo.RocketAPI.GeneratedCode.PayloadsReflection.Descriptor.MessageTypes[59]; }
-        }
-
-        public ulong EncounterId
-        {
-            get { return encounterId_; }
-            set { encounterId_ = value; }
-        }
-
-        public string FortId
-        {
-            get { return fortId_; }
-            set { fortId_ = pb::ProtoPreconditions.CheckNotNull(value, "value"); }
-        }
-
-        public double PlayerLatitude
-        {
-            get { return playerLatitude_; }
-            set { playerLatitude_ = value; }
-        }
-
-        public double PlayerLongitude
-        {
-            get { return playerLongitude_; }
-            set { playerLongitude_ = value; }
-        }
-
-        pbr::MessageDescriptor pb::IMessage.Descriptor
-        {
-            get { return Descriptor; }
-        }
-
-        public DiskEncounterRequest Clone()
-        {
-            return new DiskEncounterRequest(this);
-        }
-
-        public bool Equals(DiskEncounterRequest other)
-        {
-            if (ReferenceEquals(other, null))
-            {
-                return false;
-            }
-            if (ReferenceEquals(other, this))
-            {
-                return true;
-            }
-            if (EncounterId != other.EncounterId) return false;
-            if (FortId != other.FortId) return false;
-            if (PlayerLatitude != other.PlayerLatitude) return false;
-            if (PlayerLongitude != other.PlayerLongitude) return false;
-            return true;
-        }
-
-        public void WriteTo(pb::CodedOutputStream output)
-        {
-            if (EncounterId != 0UL)
-            {
-                output.WriteRawTag(9);
-                output.WriteFixed64(EncounterId);
-            }
-            if (FortId.Length != 0)
-            {
-                output.WriteRawTag(18);
-                output.WriteString(FortId);
-            }
-            if (PlayerLatitude != 0D)
-            {
-                output.WriteRawTag(25);
-                output.WriteDouble(PlayerLatitude);
-            }
-            if (PlayerLongitude != 0D)
-            {
-                output.WriteRawTag(33);
-                output.WriteDouble(PlayerLongitude);
-            }
-        }
-
-        public int CalculateSize()
-        {
-            var size = 0;
-            if (EncounterId != 0UL)
-            {
-                size += 1 + 8;
-            }
-            if (FortId.Length != 0)
-            {
-                size += 1 + pb::CodedOutputStream.ComputeStringSize(FortId);
-            }
-            if (PlayerLatitude != 0D)
-            {
-                size += 1 + 8;
-            }
-            if (PlayerLongitude != 0D)
-            {
-                size += 1 + 8;
-            }
-            return size;
-        }
-
-        public void MergeFrom(DiskEncounterRequest other)
-        {
-            if (other == null)
-            {
-                return;
-            }
-            if (other.EncounterId != 0UL)
-            {
-                EncounterId = other.EncounterId;
-            }
-            if (other.FortId.Length != 0)
-            {
-                FortId = other.FortId;
-            }
-            if (other.PlayerLatitude != 0D)
-            {
-                PlayerLatitude = other.PlayerLatitude;
-            }
-            if (other.PlayerLongitude != 0D)
-            {
-                PlayerLongitude = other.PlayerLongitude;
-            }
-        }
-
-        public void MergeFrom(pb::CodedInputStream input)
-        {
-            uint tag;
-            while ((tag = input.ReadTag()) != 0)
-            {
-                switch (tag)
-                {
-                    default:
-                        input.SkipLastField();
-                        break;
-                    case 9:
-                        {
-                            EncounterId = input.ReadFixed64();
-                            break;
-                        }
-                    case 18:
-                        {
-                            FortId = input.ReadString();
-                            break;
-                        }
-                    case 25:
-                        {
-                            PlayerLatitude = input.ReadDouble();
-                            break;
-                        }
-                    case 33:
-                        {
-                            PlayerLongitude = input.ReadDouble();
-                            break;
-                        }
-                }
-            }
-        }
-
-        public override bool Equals(object other)
-        {
-            return Equals(other as DiskEncounterRequest);
-        }
-
-        public override int GetHashCode()
-        {
-            var hash = 1;
-            if (EncounterId != 0UL) hash ^= EncounterId.GetHashCode();
-            if (FortId.Length != 0) hash ^= FortId.GetHashCode();
-            if (PlayerLatitude != 0D) hash ^= PlayerLatitude.GetHashCode();
-            if (PlayerLongitude != 0D) hash ^= PlayerLongitude.GetHashCode();
-            return hash;
-        }
-
-        partial void OnConstruction();
-
-        public override string ToString()
-        {
-            return pb::JsonFormatter.ToDiagnosticString(this);
-        }
-    }
-
-    [global::System.Diagnostics.DebuggerNonUserCodeAttribute()]
-    public sealed partial class DiskEncounterResponse : pb::IMessage<DiskEncounterResponse>
-    {
-        /// <summary>Field number for the "result" field.</summary>
-        public const int ResultFieldNumber = 1;
-
-        /// <summary>Field number for the "pokemon_data" field.</summary>
-        public const int PokemonDataFieldNumber = 2;
-
-        /// <summary>Field number for the "capture_probability" field.</summary>
-        public const int CaptureProbabilityFieldNumber = 3;
-
-        private static readonly pb::MessageParser<DiskEncounterResponse> _parser =
-            new pb::MessageParser<DiskEncounterResponse>(() => new DiskEncounterResponse());
-
-        private global::PokemonGo.RocketAPI.GeneratedCode.CaptureProbability captureProbability_;
-        private global::PokemonGo.RocketAPI.GeneratedCode.PokemonData pokemonData_;
-        private global::PokemonGo.RocketAPI.GeneratedCode.DiskEncounterResponse.Types.Result result_ = 0;
-
-        public DiskEncounterResponse()
-        {
-            OnConstruction();
-        }
-
-        public DiskEncounterResponse(DiskEncounterResponse other) : this()
-        {
-            result_ = other.result_;
-            PokemonData = other.pokemonData_ != null ? other.PokemonData.Clone() : null;
-            CaptureProbability = other.captureProbability_ != null ? other.CaptureProbability.Clone() : null;
-        }
-
-        public static pb::MessageParser<DiskEncounterResponse> Parser
-        {
-            get { return _parser; }
-        }
-
-        public static pbr::MessageDescriptor Descriptor
-        {
-            get { return global::PokemonGo.RocketAPI.GeneratedCode.PayloadsReflection.Descriptor.MessageTypes[60]; }
-        }
-
-        public global::PokemonGo.RocketAPI.GeneratedCode.DiskEncounterResponse.Types.Result Result
-        {
-            get { return result_; }
-            set { result_ = value; }
-        }
-
-        public global::PokemonGo.RocketAPI.GeneratedCode.PokemonData PokemonData
-        {
-            get { return pokemonData_; }
-            set { pokemonData_ = value; }
-        }
-
-        public global::PokemonGo.RocketAPI.GeneratedCode.CaptureProbability CaptureProbability
-        {
-            get { return captureProbability_; }
-            set { captureProbability_ = value; }
-        }
-
-        pbr::MessageDescriptor pb::IMessage.Descriptor
-        {
-            get { return Descriptor; }
-        }
-
-        public DiskEncounterResponse Clone()
-        {
-            return new DiskEncounterResponse(this);
-        }
-
-        public bool Equals(DiskEncounterResponse other)
-        {
-            if (ReferenceEquals(other, null))
-            {
-                return false;
-            }
-            if (ReferenceEquals(other, this))
-            {
-                return true;
-            }
-            if (Result != other.Result) return false;
-            if (!Equals(PokemonData, other.PokemonData)) return false;
-            if (!Equals(CaptureProbability, other.CaptureProbability)) return false;
-            return true;
-        }
-
-        public void WriteTo(pb::CodedOutputStream output)
-        {
-            if (Result != 0)
-            {
-                output.WriteRawTag(8);
-                output.WriteEnum((int)Result);
-            }
-            if (pokemonData_ != null)
-            {
-                output.WriteRawTag(18);
-                output.WriteMessage(PokemonData);
-            }
-            if (captureProbability_ != null)
-            {
-                output.WriteRawTag(26);
-                output.WriteMessage(CaptureProbability);
-            }
-        }
-
-        public int CalculateSize()
-        {
-            var size = 0;
-            if (Result != 0)
-            {
-                size += 1 + pb::CodedOutputStream.ComputeEnumSize((int)Result);
-            }
-            if (pokemonData_ != null)
-            {
-                size += 1 + pb::CodedOutputStream.ComputeMessageSize(PokemonData);
-            }
-            if (captureProbability_ != null)
-            {
-                size += 1 + pb::CodedOutputStream.ComputeMessageSize(CaptureProbability);
-            }
-            return size;
-        }
-
-        public void MergeFrom(DiskEncounterResponse other)
-        {
-            if (other == null)
-            {
-                return;
-            }
-            if (other.Result != 0)
-            {
-                Result = other.Result;
-            }
-            if (other.pokemonData_ != null)
-            {
-                if (pokemonData_ == null)
-                {
-                    pokemonData_ = new global::PokemonGo.RocketAPI.GeneratedCode.PokemonData();
-                }
-                PokemonData.MergeFrom(other.PokemonData);
-            }
-            if (other.captureProbability_ != null)
-            {
-                if (captureProbability_ == null)
-                {
-                    captureProbability_ = new global::PokemonGo.RocketAPI.GeneratedCode.CaptureProbability();
-                }
-                CaptureProbability.MergeFrom(other.CaptureProbability);
-            }
-        }
-
-        public void MergeFrom(pb::CodedInputStream input)
-        {
-            uint tag;
-            while ((tag = input.ReadTag()) != 0)
-            {
-                switch (tag)
-                {
-                    default:
-                        input.SkipLastField();
-                        break;
-                    case 8:
-                        {
-                            result_ =
-                                (global::PokemonGo.RocketAPI.GeneratedCode.DiskEncounterResponse.Types.Result)
-                                    input.ReadEnum();
-                            break;
-                        }
-                    case 18:
-                        {
-                            if (pokemonData_ == null)
-                            {
-                                pokemonData_ = new global::PokemonGo.RocketAPI.GeneratedCode.PokemonData();
-                            }
-                            input.ReadMessage(pokemonData_);
-                            break;
-                        }
-                    case 26:
-                        {
-                            if (captureProbability_ == null)
-                            {
-                                captureProbability_ = new global::PokemonGo.RocketAPI.GeneratedCode.CaptureProbability();
-                            }
-                            input.ReadMessage(captureProbability_);
-                            break;
-                        }
-                }
-            }
-        }
-
-        public override bool Equals(object other)
-        {
-            return Equals(other as DiskEncounterResponse);
-        }
-
-        public override int GetHashCode()
-        {
-            var hash = 1;
-            if (Result != 0) hash ^= Result.GetHashCode();
-            if (pokemonData_ != null) hash ^= PokemonData.GetHashCode();
-            if (captureProbability_ != null) hash ^= CaptureProbability.GetHashCode();
-            return hash;
-        }
-
-        partial void OnConstruction();
-
-        public override string ToString()
-        {
-            return pb::JsonFormatter.ToDiagnosticString(this);
-        }
-
-        #region Nested types
-
-        /// <summary>Container for nested types declared in the DiskEncounterResponse message type.</summary>
-        [global::System.Diagnostics.DebuggerNonUserCodeAttribute()]
-        public static partial class Types
-        {
-            public enum Result
-            {
-                [pbr::OriginalName("UNKNOWN")]
-                Unknown = 0,
-                [pbr::OriginalName("SUCCESS")]
-                Success = 1,
-                [pbr::OriginalName("NOT_AVAILABLE")]
-                NotAvailable = 2,
-                [pbr::OriginalName("NOT_IN_RANGE")]
-                NotInRange = 3,
-                [pbr::OriginalName("ENCOUNTER_ALREADY_FINISHED")]
-                EncounterAlreadyFinished = 4,
-                [pbr::OriginalName("POKEMON_INVENTORY_FULL")]
-                PokemonInventoryFull = 5,
-            }
-        }
-
-        #endregion
-    }
-
-    [global::System.Diagnostics.DebuggerNonUserCodeAttribute()]
-    public sealed partial class CatchPokemonRequest : pb::IMessage<CatchPokemonRequest>
-    {
-        /// <summary>Field number for the "encounter_id" field.</summary>
-        public const int EncounterIdFieldNumber = 1;
-
-        /// <summary>Field number for the "pokeball" field.</summary>
-        public const int PokeballFieldNumber = 2;
-
-        /// <summary>Field number for the "normalized_reticle_size" field.</summary>
-        public const int NormalizedReticleSizeFieldNumber = 3;
-
-        /// <summary>Field number for the "spawn_point_guid" field.</summary>
-        public const int SpawnPointGuidFieldNumber = 4;
-
-        /// <summary>Field number for the "hit_pokemon" field.</summary>
-        public const int HitPokemonFieldNumber = 5;
-
-        /// <summary>Field number for the "spin_modifier" field.</summary>
-        public const int SpinModifierFieldNumber = 6;
-
-        /// <summary>Field number for the "NormalizedHitPosition" field.</summary>
-        public const int NormalizedHitPositionFieldNumber = 7;
-
-        private static readonly pb::MessageParser<CatchPokemonRequest> _parser =
-            new pb::MessageParser<CatchPokemonRequest>(() => new CatchPokemonRequest());
-
-        private ulong encounterId_;
-        private bool hitPokemon_;
-        private double normalizedHitPosition_;
-        private double normalizedReticleSize_;
-        private int pokeball_;
-        private string spawnPointGuid_ = "";
-        private double spinModifier_;
-
-        public CatchPokemonRequest()
-        {
-            OnConstruction();
-        }
-
-        public CatchPokemonRequest(CatchPokemonRequest other) : this()
-        {
-            encounterId_ = other.encounterId_;
-            pokeball_ = other.pokeball_;
-            normalizedReticleSize_ = other.normalizedReticleSize_;
-            spawnPointGuid_ = other.spawnPointGuid_;
-            hitPokemon_ = other.hitPokemon_;
-            spinModifier_ = other.spinModifier_;
-            normalizedHitPosition_ = other.normalizedHitPosition_;
-        }
-
-        public static pb::MessageParser<CatchPokemonRequest> Parser
-        {
-            get { return _parser; }
-        }
-
-        public static pbr::MessageDescriptor Descriptor
-        {
-            get { return global::PokemonGo.RocketAPI.GeneratedCode.PayloadsReflection.Descriptor.MessageTypes[61]; }
-        }
-
-        public ulong EncounterId
-        {
-            get { return encounterId_; }
-            set { encounterId_ = value; }
-        }
-
-        public int Pokeball
-        {
-            get { return pokeball_; }
-            set { pokeball_ = value; }
-        }
-
-        public double NormalizedReticleSize
-        {
-            get { return normalizedReticleSize_; }
-            set { normalizedReticleSize_ = value; }
-        }
-
-        public string SpawnPointGuid
-        {
-            get { return spawnPointGuid_; }
-            set { spawnPointGuid_ = pb::ProtoPreconditions.CheckNotNull(value, "value"); }
-        }
-
-        public bool HitPokemon
-        {
-            get { return hitPokemon_; }
-            set { hitPokemon_ = value; }
-        }
-
-        public double SpinModifier
-        {
-            get { return spinModifier_; }
-            set { spinModifier_ = value; }
-        }
-
-        public double NormalizedHitPosition
-        {
-            get { return normalizedHitPosition_; }
-            set { normalizedHitPosition_ = value; }
-        }
-
-        pbr::MessageDescriptor pb::IMessage.Descriptor
-        {
-            get { return Descriptor; }
-        }
-
-        public CatchPokemonRequest Clone()
-        {
-            return new CatchPokemonRequest(this);
-        }
-
-        public bool Equals(CatchPokemonRequest other)
-        {
-            if (ReferenceEquals(other, null))
-            {
-                return false;
-            }
-            if (ReferenceEquals(other, this))
-            {
-                return true;
-            }
-            if (EncounterId != other.EncounterId) return false;
-            if (Pokeball != other.Pokeball) return false;
-            if (NormalizedReticleSize != other.NormalizedReticleSize) return false;
-            if (SpawnPointGuid != other.SpawnPointGuid) return false;
-            if (HitPokemon != other.HitPokemon) return false;
-            if (SpinModifier != other.SpinModifier) return false;
-            if (NormalizedHitPosition != other.NormalizedHitPosition) return false;
-            return true;
-        }
-
-        public void WriteTo(pb::CodedOutputStream output)
-        {
-            if (EncounterId != 0UL)
-            {
-                output.WriteRawTag(9);
-                output.WriteFixed64(EncounterId);
-            }
-            if (Pokeball != 0)
-            {
-                output.WriteRawTag(16);
-                output.WriteInt32(Pokeball);
-            }
-            if (NormalizedReticleSize != 0D)
-            {
-                output.WriteRawTag(25);
-                output.WriteDouble(NormalizedReticleSize);
-            }
-            if (SpawnPointGuid.Length != 0)
-            {
-                output.WriteRawTag(34);
-                output.WriteString(SpawnPointGuid);
-            }
-            if (HitPokemon != false)
-            {
-                output.WriteRawTag(40);
-                output.WriteBool(HitPokemon);
-            }
-            if (SpinModifier != 0D)
-            {
-                output.WriteRawTag(49);
-                output.WriteDouble(SpinModifier);
-            }
-            if (NormalizedHitPosition != 0D)
-            {
-                output.WriteRawTag(57);
-                output.WriteDouble(NormalizedHitPosition);
-            }
-        }
-
-        public int CalculateSize()
-        {
-            var size = 0;
-            if (EncounterId != 0UL)
-            {
-                size += 1 + 8;
-            }
-            if (Pokeball != 0)
-            {
-                size += 1 + pb::CodedOutputStream.ComputeInt32Size(Pokeball);
-            }
-            if (NormalizedReticleSize != 0D)
-            {
-                size += 1 + 8;
-            }
-            if (SpawnPointGuid.Length != 0)
-            {
-                size += 1 + pb::CodedOutputStream.ComputeStringSize(SpawnPointGuid);
-            }
-            if (HitPokemon != false)
-            {
-                size += 1 + 1;
-            }
-            if (SpinModifier != 0D)
-            {
-                size += 1 + 8;
-            }
-            if (NormalizedHitPosition != 0D)
-            {
-                size += 1 + 8;
-            }
-            return size;
-        }
-
-        public void MergeFrom(CatchPokemonRequest other)
-        {
-            if (other == null)
-            {
-                return;
-            }
-            if (other.EncounterId != 0UL)
-            {
-                EncounterId = other.EncounterId;
-            }
-            if (other.Pokeball != 0)
-            {
-                Pokeball = other.Pokeball;
-            }
-            if (other.NormalizedReticleSize != 0D)
-            {
-                NormalizedReticleSize = other.NormalizedReticleSize;
-            }
-            if (other.SpawnPointGuid.Length != 0)
-            {
-                SpawnPointGuid = other.SpawnPointGuid;
-            }
-            if (other.HitPokemon != false)
-            {
-                HitPokemon = other.HitPokemon;
-            }
-            if (other.SpinModifier != 0D)
-            {
-                SpinModifier = other.SpinModifier;
-            }
-            if (other.NormalizedHitPosition != 0D)
-            {
-                NormalizedHitPosition = other.NormalizedHitPosition;
-            }
-        }
-
-        public void MergeFrom(pb::CodedInputStream input)
-        {
-            uint tag;
-            while ((tag = input.ReadTag()) != 0)
-            {
-                switch (tag)
-                {
-                    default:
-                        input.SkipLastField();
-                        break;
-                    case 9:
-                        {
-                            EncounterId = input.ReadFixed64();
-                            break;
-                        }
-                    case 16:
-                        {
-                            Pokeball = input.ReadInt32();
-                            break;
-                        }
-                    case 25:
-                        {
-                            NormalizedReticleSize = input.ReadDouble();
-                            break;
-                        }
-                    case 34:
-                        {
-                            SpawnPointGuid = input.ReadString();
-                            break;
-                        }
-                    case 40:
-                        {
-                            HitPokemon = input.ReadBool();
-                            break;
-                        }
-                    case 49:
-                        {
-                            SpinModifier = input.ReadDouble();
-                            break;
-                        }
-                    case 57:
-                        {
-                            NormalizedHitPosition = input.ReadDouble();
-                            break;
-                        }
-                }
-            }
-        }
-
-        public override bool Equals(object other)
-        {
-            return Equals(other as CatchPokemonRequest);
-        }
-
-        public override int GetHashCode()
-        {
-            var hash = 1;
-            if (EncounterId != 0UL) hash ^= EncounterId.GetHashCode();
-            if (Pokeball != 0) hash ^= Pokeball.GetHashCode();
-            if (NormalizedReticleSize != 0D) hash ^= NormalizedReticleSize.GetHashCode();
-            if (SpawnPointGuid.Length != 0) hash ^= SpawnPointGuid.GetHashCode();
-            if (HitPokemon != false) hash ^= HitPokemon.GetHashCode();
-            if (SpinModifier != 0D) hash ^= SpinModifier.GetHashCode();
-            if (NormalizedHitPosition != 0D) hash ^= NormalizedHitPosition.GetHashCode();
-            return hash;
-        }
-
-        partial void OnConstruction();
-
-        public override string ToString()
-        {
-            return pb::JsonFormatter.ToDiagnosticString(this);
-        }
-    }
-
-    [global::System.Diagnostics.DebuggerNonUserCodeAttribute()]
-    public sealed partial class CatchPokemonResponse : pb::IMessage<CatchPokemonResponse>
-    {
-        /// <summary>Field number for the "status" field.</summary>
-        public const int StatusFieldNumber = 1;
-
-        /// <summary>Field number for the "miss_percent" field.</summary>
-        public const int MissPercentFieldNumber = 2;
-
-        /// <summary>Field number for the "captured_pokemon_id" field.</summary>
-        public const int CapturedPokemonIdFieldNumber = 3;
-
-        /// <summary>Field number for the "scores" field.</summary>
-        public const int ScoresFieldNumber = 4;
-
-        private static readonly pb::MessageParser<CatchPokemonResponse> _parser =
-            new pb::MessageParser<CatchPokemonResponse>(() => new CatchPokemonResponse());
-
-        private ulong capturedPokemonId_;
-        private double missPercent_;
-        private global::PokemonGo.RocketAPI.GeneratedCode.CaptureScore scores_;
-        private global::PokemonGo.RocketAPI.GeneratedCode.CatchPokemonResponse.Types.CatchStatus status_ = 0;
-
-        public CatchPokemonResponse()
-        {
-            OnConstruction();
-        }
-
-        public CatchPokemonResponse(CatchPokemonResponse other) : this()
-        {
-            status_ = other.status_;
-            missPercent_ = other.missPercent_;
-            capturedPokemonId_ = other.capturedPokemonId_;
-            Scores = other.scores_ != null ? other.Scores.Clone() : null;
-        }
-
-        public static pb::MessageParser<CatchPokemonResponse> Parser
-        {
-            get { return _parser; }
-        }
-
-        public static pbr::MessageDescriptor Descriptor
-        {
-            get { return global::PokemonGo.RocketAPI.GeneratedCode.PayloadsReflection.Descriptor.MessageTypes[62]; }
-        }
-
-        public global::PokemonGo.RocketAPI.GeneratedCode.CatchPokemonResponse.Types.CatchStatus Status
-        {
-            get { return status_; }
-            set { status_ = value; }
-        }
-
-        public double MissPercent
-        {
-            get { return missPercent_; }
-            set { missPercent_ = value; }
-        }
-
-        public ulong CapturedPokemonId
-        {
-            get { return capturedPokemonId_; }
-            set { capturedPokemonId_ = value; }
-        }
-
-        public global::PokemonGo.RocketAPI.GeneratedCode.CaptureScore Scores
-        {
-            get { return scores_; }
-            set { scores_ = value; }
-        }
-
-        pbr::MessageDescriptor pb::IMessage.Descriptor
-        {
-            get { return Descriptor; }
-        }
-
-        public CatchPokemonResponse Clone()
-        {
-            return new CatchPokemonResponse(this);
-        }
-
-        public bool Equals(CatchPokemonResponse other)
-        {
-            if (ReferenceEquals(other, null))
-            {
-                return false;
-            }
-            if (ReferenceEquals(other, this))
-            {
-                return true;
-            }
-            if (Status != other.Status) return false;
-            if (MissPercent != other.MissPercent) return false;
-            if (CapturedPokemonId != other.CapturedPokemonId) return false;
-            if (!Equals(Scores, other.Scores)) return false;
-            return true;
-        }
-
-        public void WriteTo(pb::CodedOutputStream output)
-        {
-            if (Status != 0)
-            {
-                output.WriteRawTag(8);
-                output.WriteEnum((int)Status);
-            }
-            if (MissPercent != 0D)
-            {
-                output.WriteRawTag(17);
-                output.WriteDouble(MissPercent);
-            }
-            if (CapturedPokemonId != 0UL)
-            {
-                output.WriteRawTag(24);
-                output.WriteUInt64(CapturedPokemonId);
-            }
-            if (scores_ != null)
-            {
-                output.WriteRawTag(34);
-                output.WriteMessage(Scores);
-            }
-        }
-
-        public int CalculateSize()
-        {
-            var size = 0;
-            if (Status != 0)
-            {
-                size += 1 + pb::CodedOutputStream.ComputeEnumSize((int)Status);
-            }
-            if (MissPercent != 0D)
-            {
-                size += 1 + 8;
-            }
-            if (CapturedPokemonId != 0UL)
-            {
-                size += 1 + pb::CodedOutputStream.ComputeUInt64Size(CapturedPokemonId);
-            }
-            if (scores_ != null)
-            {
-                size += 1 + pb::CodedOutputStream.ComputeMessageSize(Scores);
-            }
-            return size;
-        }
-
-        public void MergeFrom(CatchPokemonResponse other)
-        {
-            if (other == null)
-            {
-                return;
-            }
-            if (other.Status != 0)
-            {
-                Status = other.Status;
-            }
-            if (other.MissPercent != 0D)
-            {
-                MissPercent = other.MissPercent;
-            }
-            if (other.CapturedPokemonId != 0UL)
-            {
-                CapturedPokemonId = other.CapturedPokemonId;
-            }
-            if (other.scores_ != null)
-            {
-                if (scores_ == null)
-                {
-                    scores_ = new global::PokemonGo.RocketAPI.GeneratedCode.CaptureScore();
-                }
-                Scores.MergeFrom(other.Scores);
-            }
-        }
-
-        public void MergeFrom(pb::CodedInputStream input)
-        {
-            uint tag;
-            while ((tag = input.ReadTag()) != 0)
-            {
-                switch (tag)
-                {
-                    default:
-                        input.SkipLastField();
-                        break;
-                    case 8:
-                        {
-                            status_ =
-                                (global::PokemonGo.RocketAPI.GeneratedCode.CatchPokemonResponse.Types.CatchStatus)
-                                    input.ReadEnum();
-                            break;
-                        }
-                    case 17:
-                        {
-                            MissPercent = input.ReadDouble();
-                            break;
-                        }
-                    case 24:
-                        {
-                            CapturedPokemonId = input.ReadUInt64();
-                            break;
-                        }
-                    case 34:
-                        {
-                            if (scores_ == null)
-                            {
-                                scores_ = new global::PokemonGo.RocketAPI.GeneratedCode.CaptureScore();
-                            }
-                            input.ReadMessage(scores_);
-                            break;
-                        }
-                }
-            }
-        }
-
-        public override bool Equals(object other)
-        {
-            return Equals(other as CatchPokemonResponse);
-        }
-
-        public override int GetHashCode()
-        {
-            var hash = 1;
-            if (Status != 0) hash ^= Status.GetHashCode();
-            if (MissPercent != 0D) hash ^= MissPercent.GetHashCode();
-            if (CapturedPokemonId != 0UL) hash ^= CapturedPokemonId.GetHashCode();
-            if (scores_ != null) hash ^= Scores.GetHashCode();
-            return hash;
-        }
-
-        partial void OnConstruction();
-
-        public override string ToString()
-        {
-            return pb::JsonFormatter.ToDiagnosticString(this);
-        }
-
-        #region Nested types
-
-        /// <summary>Container for nested types declared in the CatchPokemonResponse message type.</summary>
-        [global::System.Diagnostics.DebuggerNonUserCodeAttribute()]
-        public static partial class Types
-        {
-            public enum CatchStatus
-            {
-                [pbr::OriginalName("CATCH_ERROR")]
-                CatchError = 0,
-                [pbr::OriginalName("CATCH_SUCCESS")]
-                CatchSuccess = 1,
-                [pbr::OriginalName("CATCH_ESCAPE")]
-                CatchEscape = 2,
-                [pbr::OriginalName("CATCH_FLEE")]
-                CatchFlee = 3,
-                [pbr::OriginalName("CATCH_MISSED")]
-                CatchMissed = 4,
-            }
-        }
-
-        #endregion
-    }
-
-    [global::System.Diagnostics.DebuggerNonUserCodeAttribute()]
-    public sealed partial class CaptureScore : pb::IMessage<CaptureScore>
-    {
-        /// <summary>Field number for the "activity_type" field.</summary>
-        public const int ActivityTypeFieldNumber = 1;
-
-        /// <summary>Field number for the "xp" field.</summary>
-        public const int XpFieldNumber = 2;
-
-        /// <summary>Field number for the "candy" field.</summary>
-        public const int CandyFieldNumber = 3;
-
-        /// <summary>Field number for the "stardust" field.</summary>
-        public const int StardustFieldNumber = 4;
-
-        private static readonly pb::MessageParser<CaptureScore> _parser =
-            new pb::MessageParser<CaptureScore>(() => new CaptureScore());
-
-        private static readonly pb::FieldCodec<global::PokemonGo.RocketAPI.GeneratedCode.ActivityType>
-            _repeated_activityType_codec
-                = pb::FieldCodec.ForEnum(10, x => (int)x,
-                    x => (global::PokemonGo.RocketAPI.GeneratedCode.ActivityType)x);
-
-        private static readonly pb::FieldCodec<int> _repeated_xp_codec
-            = pb::FieldCodec.ForInt32(18);
-
-        private static readonly pb::FieldCodec<int> _repeated_candy_codec
-            = pb::FieldCodec.ForInt32(26);
-
-        private static readonly pb::FieldCodec<int> _repeated_stardust_codec
-            = pb::FieldCodec.ForInt32(34);
-
-        private readonly pbc::RepeatedField<global::PokemonGo.RocketAPI.GeneratedCode.ActivityType> activityType_ =
-            new pbc::RepeatedField<global::PokemonGo.RocketAPI.GeneratedCode.ActivityType>();
-
-        private readonly pbc::RepeatedField<int> candy_ = new pbc::RepeatedField<int>();
-        private readonly pbc::RepeatedField<int> stardust_ = new pbc::RepeatedField<int>();
-        private readonly pbc::RepeatedField<int> xp_ = new pbc::RepeatedField<int>();
-
-        public CaptureScore()
-        {
-            OnConstruction();
-        }
-
-        public CaptureScore(CaptureScore other) : this()
-        {
-            activityType_ = other.activityType_.Clone();
-            xp_ = other.xp_.Clone();
-            candy_ = other.candy_.Clone();
-            stardust_ = other.stardust_.Clone();
-        }
-
-        public static pb::MessageParser<CaptureScore> Parser
-        {
-            get { return _parser; }
-        }
-
-        public static pbr::MessageDescriptor Descriptor
-        {
-            get { return global::PokemonGo.RocketAPI.GeneratedCode.PayloadsReflection.Descriptor.MessageTypes[63]; }
-        }
-
-        public pbc::RepeatedField<global::PokemonGo.RocketAPI.GeneratedCode.ActivityType> ActivityType
-        {
-            get { return activityType_; }
-        }
-
-        public pbc::RepeatedField<int> Xp
-        {
-            get { return xp_; }
-        }
-
-        public pbc::RepeatedField<int> Candy
-        {
-            get { return candy_; }
-        }
-
-        public pbc::RepeatedField<int> Stardust
-        {
-            get { return stardust_; }
-        }
-
-        pbr::MessageDescriptor pb::IMessage.Descriptor
-        {
-            get { return Descriptor; }
-        }
-
-        public CaptureScore Clone()
-        {
-            return new CaptureScore(this);
-        }
-
-        public bool Equals(CaptureScore other)
-        {
-            if (ReferenceEquals(other, null))
-            {
-                return false;
-            }
-            if (ReferenceEquals(other, this))
-            {
-                return true;
-            }
-            if (!activityType_.Equals(other.activityType_)) return false;
-            if (!xp_.Equals(other.xp_)) return false;
-            if (!candy_.Equals(other.candy_)) return false;
-            if (!stardust_.Equals(other.stardust_)) return false;
-            return true;
-        }
-
-        public void WriteTo(pb::CodedOutputStream output)
-        {
-            activityType_.WriteTo(output, _repeated_activityType_codec);
-            xp_.WriteTo(output, _repeated_xp_codec);
-            candy_.WriteTo(output, _repeated_candy_codec);
-            stardust_.WriteTo(output, _repeated_stardust_codec);
-        }
-
-        public int CalculateSize()
-        {
-            var size = 0;
-            size += activityType_.CalculateSize(_repeated_activityType_codec);
-            size += xp_.CalculateSize(_repeated_xp_codec);
-            size += candy_.CalculateSize(_repeated_candy_codec);
-            size += stardust_.CalculateSize(_repeated_stardust_codec);
-            return size;
-        }
-
-        public void MergeFrom(CaptureScore other)
-        {
-            if (other == null)
-            {
-                return;
-            }
-            activityType_.Add(other.activityType_);
-            xp_.Add(other.xp_);
-            candy_.Add(other.candy_);
-            stardust_.Add(other.stardust_);
-        }
-
-        public void MergeFrom(pb::CodedInputStream input)
-        {
-            uint tag;
-            while ((tag = input.ReadTag()) != 0)
-            {
-                switch (tag)
-                {
-                    default:
-                        input.SkipLastField();
-                        break;
-                    case 10:
-                    case 8:
-                        {
-                            activityType_.AddEntriesFrom(input, _repeated_activityType_codec);
-                            break;
-                        }
-                    case 18:
-                    case 16:
-                        {
-                            xp_.AddEntriesFrom(input, _repeated_xp_codec);
-                            break;
-                        }
-                    case 26:
-                    case 24:
-                        {
-                            candy_.AddEntriesFrom(input, _repeated_candy_codec);
-                            break;
-                        }
-                    case 34:
-                    case 32:
-                        {
-                            stardust_.AddEntriesFrom(input, _repeated_stardust_codec);
-                            break;
-                        }
-                }
-            }
-        }
-
-        public override bool Equals(object other)
-        {
-            return Equals(other as CaptureScore);
-        }
-
-        public override int GetHashCode()
-        {
-            var hash = 1;
-            hash ^= activityType_.GetHashCode();
-            hash ^= xp_.GetHashCode();
-            hash ^= candy_.GetHashCode();
-            hash ^= stardust_.GetHashCode();
-            return hash;
-        }
-
-        partial void OnConstruction();
-
-        public override string ToString()
-        {
-            return pb::JsonFormatter.ToDiagnosticString(this);
-        }
-    }
-
-    /// <summary>
-    ///     No message needed.
-    /// </summary>
-    [global::System.Diagnostics.DebuggerNonUserCodeAttribute()]
-    public sealed partial class CheckAwardedBadgesRequest : pb::IMessage<CheckAwardedBadgesRequest>
-    {
-        private static readonly pb::MessageParser<CheckAwardedBadgesRequest> _parser =
-            new pb::MessageParser<CheckAwardedBadgesRequest>(() => new CheckAwardedBadgesRequest());
-
-        public CheckAwardedBadgesRequest()
-        {
-            OnConstruction();
-        }
-
-        public CheckAwardedBadgesRequest(CheckAwardedBadgesRequest other) : this()
-        {
-        }
-
-        public static pb::MessageParser<CheckAwardedBadgesRequest> Parser
-        {
-            get { return _parser; }
-        }
-
-        public static pbr::MessageDescriptor Descriptor
-        {
-            get { return global::PokemonGo.RocketAPI.GeneratedCode.PayloadsReflection.Descriptor.MessageTypes[64]; }
-        }
-
-        pbr::MessageDescriptor pb::IMessage.Descriptor
-        {
-            get { return Descriptor; }
-        }
-
-        public CheckAwardedBadgesRequest Clone()
-        {
-            return new CheckAwardedBadgesRequest(this);
-        }
-
-        public bool Equals(CheckAwardedBadgesRequest other)
-        {
-            if (ReferenceEquals(other, null))
-            {
-                return false;
-            }
-            if (ReferenceEquals(other, this))
-            {
-                return true;
-            }
-            return true;
-        }
-
-        public void WriteTo(pb::CodedOutputStream output)
-        {
-        }
-
-        public int CalculateSize()
-        {
-            var size = 0;
-            return size;
-        }
-
-        public void MergeFrom(CheckAwardedBadgesRequest other)
-        {
-            if (other == null)
-            {
-                return;
-            }
-        }
-
-        public void MergeFrom(pb::CodedInputStream input)
-        {
-            uint tag;
-            while ((tag = input.ReadTag()) != 0)
-            {
-                switch (tag)
-                {
-                    default:
-                        input.SkipLastField();
-                        break;
-                }
-            }
-        }
-
-        public override bool Equals(object other)
-        {
-            return Equals(other as CheckAwardedBadgesRequest);
-        }
-
-        public override int GetHashCode()
-        {
-            var hash = 1;
-            return hash;
-        }
-
-        partial void OnConstruction();
-
-        public override string ToString()
-        {
-            return pb::JsonFormatter.ToDiagnosticString(this);
-        }
-    }
-
-    /// <summary>
-    ///     Confirm if this is correct, I think that it should be "repeated AwardedBadge awarded_badges" or something like
-    ///     that.
-    /// </summary>
-    [global::System.Diagnostics.DebuggerNonUserCodeAttribute()]
-    public sealed partial class CheckAwardedBadgesResponse : pb::IMessage<CheckAwardedBadgesResponse>
-    {
-        /// <summary>Field number for the "success" field.</summary>
-        public const int SuccessFieldNumber = 1;
-
-        /// <summary>Field number for the "awarded_badges" field.</summary>
-        public const int AwardedBadgesFieldNumber = 2;
-
-        /// <summary>Field number for the "awarded_badge_levels" field.</summary>
-        public const int AwardedBadgeLevelsFieldNumber = 3;
-
-        private static readonly pb::MessageParser<CheckAwardedBadgesResponse> _parser =
-            new pb::MessageParser<CheckAwardedBadgesResponse>(() => new CheckAwardedBadgesResponse());
-
-        private static readonly pb::FieldCodec<global::PokemonGo.RocketAPI.GeneratedCode.BadgeType>
-            _repeated_awardedBadges_codec
-                = pb::FieldCodec.ForEnum(18, x => (int)x, x => (global::PokemonGo.RocketAPI.GeneratedCode.BadgeType)x);
-
-        private static readonly pb::FieldCodec<int> _repeated_awardedBadgeLevels_codec
-            = pb::FieldCodec.ForInt32(26);
-
-        private readonly pbc::RepeatedField<int> awardedBadgeLevels_ = new pbc::RepeatedField<int>();
-
-        private readonly pbc::RepeatedField<global::PokemonGo.RocketAPI.GeneratedCode.BadgeType> awardedBadges_ =
-            new pbc::RepeatedField<global::PokemonGo.RocketAPI.GeneratedCode.BadgeType>();
-
-        private bool success_;
-
-        public CheckAwardedBadgesResponse()
-        {
-            OnConstruction();
-        }
-
-        public CheckAwardedBadgesResponse(CheckAwardedBadgesResponse other) : this()
-        {
-            success_ = other.success_;
-            awardedBadges_ = other.awardedBadges_.Clone();
-            awardedBadgeLevels_ = other.awardedBadgeLevels_.Clone();
-        }
-
-        public static pb::MessageParser<CheckAwardedBadgesResponse> Parser
-        {
-            get { return _parser; }
-        }
-
-        public static pbr::MessageDescriptor Descriptor
-        {
-            get { return global::PokemonGo.RocketAPI.GeneratedCode.PayloadsReflection.Descriptor.MessageTypes[65]; }
-        }
-
-        public bool Success
-        {
-            get { return success_; }
-            set { success_ = value; }
-        }
-
-        public pbc::RepeatedField<global::PokemonGo.RocketAPI.GeneratedCode.BadgeType> AwardedBadges
-        {
-            get { return awardedBadges_; }
-        }
-
-        public pbc::RepeatedField<int> AwardedBadgeLevels
-        {
-            get { return awardedBadgeLevels_; }
-        }
-
-        pbr::MessageDescriptor pb::IMessage.Descriptor
-        {
-            get { return Descriptor; }
-        }
-
-        public CheckAwardedBadgesResponse Clone()
-        {
-            return new CheckAwardedBadgesResponse(this);
-        }
-
-        public bool Equals(CheckAwardedBadgesResponse other)
-        {
-            if (ReferenceEquals(other, null))
-            {
-                return false;
-            }
-            if (ReferenceEquals(other, this))
-            {
-                return true;
-            }
-            if (Success != other.Success) return false;
-            if (!awardedBadges_.Equals(other.awardedBadges_)) return false;
-            if (!awardedBadgeLevels_.Equals(other.awardedBadgeLevels_)) return false;
-            return true;
-        }
-
-        public void WriteTo(pb::CodedOutputStream output)
-        {
-            if (Success != false)
-            {
-                output.WriteRawTag(8);
-                output.WriteBool(Success);
-            }
-            awardedBadges_.WriteTo(output, _repeated_awardedBadges_codec);
-            awardedBadgeLevels_.WriteTo(output, _repeated_awardedBadgeLevels_codec);
-        }
-
-        public int CalculateSize()
-        {
-            var size = 0;
-            if (Success != false)
-            {
-                size += 1 + 1;
-            }
-            size += awardedBadges_.CalculateSize(_repeated_awardedBadges_codec);
-            size += awardedBadgeLevels_.CalculateSize(_repeated_awardedBadgeLevels_codec);
-            return size;
-        }
-
-        public void MergeFrom(CheckAwardedBadgesResponse other)
-        {
-            if (other == null)
-            {
-                return;
-            }
-            if (other.Success != false)
-            {
-                Success = other.Success;
-            }
-            awardedBadges_.Add(other.awardedBadges_);
-            awardedBadgeLevels_.Add(other.awardedBadgeLevels_);
-        }
-
-        public void MergeFrom(pb::CodedInputStream input)
-        {
-            uint tag;
-            while ((tag = input.ReadTag()) != 0)
-            {
-                switch (tag)
-                {
-                    default:
-                        input.SkipLastField();
-                        break;
-                    case 8:
-                        {
-                            Success = input.ReadBool();
-                            break;
-                        }
-                    case 18:
-                    case 16:
-                        {
-                            awardedBadges_.AddEntriesFrom(input, _repeated_awardedBadges_codec);
-                            break;
-                        }
-                    case 26:
-                    case 24:
-                        {
-                            awardedBadgeLevels_.AddEntriesFrom(input, _repeated_awardedBadgeLevels_codec);
-                            break;
-                        }
-                }
-            }
-        }
-
-        public override bool Equals(object other)
-        {
-            return Equals(other as CheckAwardedBadgesResponse);
-        }
-
-        public override int GetHashCode()
-        {
-            var hash = 1;
-            if (Success != false) hash ^= Success.GetHashCode();
-            hash ^= awardedBadges_.GetHashCode();
-            hash ^= awardedBadgeLevels_.GetHashCode();
-            return hash;
-        }
-
-        partial void OnConstruction();
-
-        public override string ToString()
-        {
-            return pb::JsonFormatter.ToDiagnosticString(this);
-        }
-    }
-
-    [global::System.Diagnostics.DebuggerNonUserCodeAttribute()]
-    public sealed partial class EquippedBadgeSettings : pb::IMessage<EquippedBadgeSettings>
-    {
-        /// <summary>Field number for the "equip_badge_cooldown_ms" field.</summary>
-        public const int EquipBadgeCooldownMsFieldNumber = 1;
-
-        /// <summary>Field number for the "catch_probability_bonus" field.</summary>
-        public const int CatchProbabilityBonusFieldNumber = 2;
-
-        /// <summary>Field number for the "flee_probability_bonus" field.</summary>
-        public const int FleeProbabilityBonusFieldNumber = 3;
-
-        private static readonly pb::MessageParser<EquippedBadgeSettings> _parser =
-            new pb::MessageParser<EquippedBadgeSettings>(() => new EquippedBadgeSettings());
-
-        private static readonly pb::FieldCodec<float> _repeated_catchProbabilityBonus_codec
-            = pb::FieldCodec.ForFloat(18);
-
-        private static readonly pb::FieldCodec<float> _repeated_fleeProbabilityBonus_codec
-            = pb::FieldCodec.ForFloat(26);
-
-        private readonly pbc::RepeatedField<float> catchProbabilityBonus_ = new pbc::RepeatedField<float>();
-        private readonly pbc::RepeatedField<float> fleeProbabilityBonus_ = new pbc::RepeatedField<float>();
-        private long equipBadgeCooldownMs_;
-
-        public EquippedBadgeSettings()
-        {
-            OnConstruction();
-        }
-
-        public EquippedBadgeSettings(EquippedBadgeSettings other) : this()
-        {
-            equipBadgeCooldownMs_ = other.equipBadgeCooldownMs_;
-            catchProbabilityBonus_ = other.catchProbabilityBonus_.Clone();
-            fleeProbabilityBonus_ = other.fleeProbabilityBonus_.Clone();
-        }
-
-        public static pb::MessageParser<EquippedBadgeSettings> Parser
-        {
-            get { return _parser; }
-        }
-
-        public static pbr::MessageDescriptor Descriptor
-        {
-            get { return global::PokemonGo.RocketAPI.GeneratedCode.PayloadsReflection.Descriptor.MessageTypes[66]; }
-        }
-
-        public long EquipBadgeCooldownMs
-        {
-            get { return equipBadgeCooldownMs_; }
-            set { equipBadgeCooldownMs_ = value; }
-        }
-
-        public pbc::RepeatedField<float> CatchProbabilityBonus
-        {
-            get { return catchProbabilityBonus_; }
-        }
-
-        public pbc::RepeatedField<float> FleeProbabilityBonus
-        {
-            get { return fleeProbabilityBonus_; }
-        }
-
-        pbr::MessageDescriptor pb::IMessage.Descriptor
-        {
-            get { return Descriptor; }
-        }
-
-        public EquippedBadgeSettings Clone()
-        {
-            return new EquippedBadgeSettings(this);
-        }
-
-        public bool Equals(EquippedBadgeSettings other)
-        {
-            if (ReferenceEquals(other, null))
-            {
-                return false;
-            }
-            if (ReferenceEquals(other, this))
-            {
-                return true;
-            }
-            if (EquipBadgeCooldownMs != other.EquipBadgeCooldownMs) return false;
-            if (!catchProbabilityBonus_.Equals(other.catchProbabilityBonus_)) return false;
-            if (!fleeProbabilityBonus_.Equals(other.fleeProbabilityBonus_)) return false;
-            return true;
-        }
-
-        public void WriteTo(pb::CodedOutputStream output)
-        {
-            if (EquipBadgeCooldownMs != 0L)
-            {
-                output.WriteRawTag(8);
-                output.WriteInt64(EquipBadgeCooldownMs);
-            }
-            catchProbabilityBonus_.WriteTo(output, _repeated_catchProbabilityBonus_codec);
-            fleeProbabilityBonus_.WriteTo(output, _repeated_fleeProbabilityBonus_codec);
-        }
-
-        public int CalculateSize()
-        {
-            var size = 0;
-            if (EquipBadgeCooldownMs != 0L)
-            {
-                size += 1 + pb::CodedOutputStream.ComputeInt64Size(EquipBadgeCooldownMs);
-            }
-            size += catchProbabilityBonus_.CalculateSize(_repeated_catchProbabilityBonus_codec);
-            size += fleeProbabilityBonus_.CalculateSize(_repeated_fleeProbabilityBonus_codec);
-            return size;
-        }
-
-        public void MergeFrom(EquippedBadgeSettings other)
-        {
-            if (other == null)
-            {
-                return;
-            }
-            if (other.EquipBadgeCooldownMs != 0L)
-            {
-                EquipBadgeCooldownMs = other.EquipBadgeCooldownMs;
-            }
-            catchProbabilityBonus_.Add(other.catchProbabilityBonus_);
-            fleeProbabilityBonus_.Add(other.fleeProbabilityBonus_);
-        }
-
-        public void MergeFrom(pb::CodedInputStream input)
-        {
-            uint tag;
-            while ((tag = input.ReadTag()) != 0)
-            {
-                switch (tag)
-                {
-                    default:
-                        input.SkipLastField();
-                        break;
-                    case 8:
-                        {
-                            EquipBadgeCooldownMs = input.ReadInt64();
-                            break;
-                        }
-                    case 18:
-                    case 21:
-                        {
-                            catchProbabilityBonus_.AddEntriesFrom(input, _repeated_catchProbabilityBonus_codec);
-                            break;
-                        }
-                    case 26:
-                    case 29:
-                        {
-                            fleeProbabilityBonus_.AddEntriesFrom(input, _repeated_fleeProbabilityBonus_codec);
-                            break;
-                        }
-                }
-            }
-        }
-
-        public override bool Equals(object other)
-        {
-            return Equals(other as EquippedBadgeSettings);
-        }
-
-        public override int GetHashCode()
-        {
-            var hash = 1;
-            if (EquipBadgeCooldownMs != 0L) hash ^= EquipBadgeCooldownMs.GetHashCode();
-            hash ^= catchProbabilityBonus_.GetHashCode();
-            hash ^= fleeProbabilityBonus_.GetHashCode();
-            return hash;
-        }
-
-        partial void OnConstruction();
-
-        public override string ToString()
-        {
-            return pb::JsonFormatter.ToDiagnosticString(this);
-        }
-    }
-
-    [global::System.Diagnostics.DebuggerNonUserCodeAttribute()]
-    public sealed partial class PokemonUpgradeSettings : pb::IMessage<PokemonUpgradeSettings>
-    {
-        /// <summary>Field number for the "upgrades_per_level" field.</summary>
-        public const int UpgradesPerLevelFieldNumber = 1;
-
-        /// <summary>Field number for the "allowed_levels_above_player" field.</summary>
-        public const int AllowedLevelsAbovePlayerFieldNumber = 2;
-
-        /// <summary>Field number for the "candy_cost" field.</summary>
-        public const int CandyCostFieldNumber = 3;
-
-        /// <summary>Field number for the "stardust_cost" field.</summary>
-        public const int StardustCostFieldNumber = 4;
-
-        private static readonly pb::MessageParser<PokemonUpgradeSettings> _parser =
-            new pb::MessageParser<PokemonUpgradeSettings>(() => new PokemonUpgradeSettings());
-
-        private static readonly pb::FieldCodec<int> _repeated_candyCost_codec
-            = pb::FieldCodec.ForInt32(26);
-
-        private static readonly pb::FieldCodec<int> _repeated_stardustCost_codec
-            = pb::FieldCodec.ForInt32(34);
-
-        private readonly pbc::RepeatedField<int> candyCost_ = new pbc::RepeatedField<int>();
-        private readonly pbc::RepeatedField<int> stardustCost_ = new pbc::RepeatedField<int>();
-        private int allowedLevelsAbovePlayer_;
-        private int upgradesPerLevel_;
-
-        public PokemonUpgradeSettings()
-        {
-            OnConstruction();
-        }
-
-        public PokemonUpgradeSettings(PokemonUpgradeSettings other) : this()
-        {
-            upgradesPerLevel_ = other.upgradesPerLevel_;
-            allowedLevelsAbovePlayer_ = other.allowedLevelsAbovePlayer_;
-            candyCost_ = other.candyCost_.Clone();
-            stardustCost_ = other.stardustCost_.Clone();
-        }
-
-        public static pb::MessageParser<PokemonUpgradeSettings> Parser
-        {
-            get { return _parser; }
-        }
-
-        public static pbr::MessageDescriptor Descriptor
-        {
-            get { return global::PokemonGo.RocketAPI.GeneratedCode.PayloadsReflection.Descriptor.MessageTypes[67]; }
-        }
-
-        public int UpgradesPerLevel
-        {
-            get { return upgradesPerLevel_; }
-            set { upgradesPerLevel_ = value; }
-        }
-
-        public int AllowedLevelsAbovePlayer
-        {
-            get { return allowedLevelsAbovePlayer_; }
-            set { allowedLevelsAbovePlayer_ = value; }
-        }
-
-        public pbc::RepeatedField<int> CandyCost
-        {
-            get { return candyCost_; }
-        }
-
-        public pbc::RepeatedField<int> StardustCost
-        {
-            get { return stardustCost_; }
-        }
-
-        pbr::MessageDescriptor pb::IMessage.Descriptor
-        {
-            get { return Descriptor; }
-        }
-
-        public PokemonUpgradeSettings Clone()
-        {
-            return new PokemonUpgradeSettings(this);
-        }
-
-        public bool Equals(PokemonUpgradeSettings other)
-        {
-            if (ReferenceEquals(other, null))
-            {
-                return false;
-            }
-            if (ReferenceEquals(other, this))
-            {
-                return true;
-            }
-            if (UpgradesPerLevel != other.UpgradesPerLevel) return false;
-            if (AllowedLevelsAbovePlayer != other.AllowedLevelsAbovePlayer) return false;
-            if (!candyCost_.Equals(other.candyCost_)) return false;
-            if (!stardustCost_.Equals(other.stardustCost_)) return false;
-            return true;
-        }
-
-        public void WriteTo(pb::CodedOutputStream output)
-        {
-            if (UpgradesPerLevel != 0)
-            {
-                output.WriteRawTag(8);
-                output.WriteInt32(UpgradesPerLevel);
-            }
-            if (AllowedLevelsAbovePlayer != 0)
-            {
-                output.WriteRawTag(16);
-                output.WriteInt32(AllowedLevelsAbovePlayer);
-            }
-            candyCost_.WriteTo(output, _repeated_candyCost_codec);
-            stardustCost_.WriteTo(output, _repeated_stardustCost_codec);
-        }
-
-        public int CalculateSize()
-        {
-            var size = 0;
-            if (UpgradesPerLevel != 0)
-            {
-                size += 1 + pb::CodedOutputStream.ComputeInt32Size(UpgradesPerLevel);
-            }
-            if (AllowedLevelsAbovePlayer != 0)
-            {
-                size += 1 + pb::CodedOutputStream.ComputeInt32Size(AllowedLevelsAbovePlayer);
-            }
-            size += candyCost_.CalculateSize(_repeated_candyCost_codec);
-            size += stardustCost_.CalculateSize(_repeated_stardustCost_codec);
-            return size;
-        }
-
-        public void MergeFrom(PokemonUpgradeSettings other)
-        {
-            if (other == null)
-            {
-                return;
-            }
-            if (other.UpgradesPerLevel != 0)
-            {
-                UpgradesPerLevel = other.UpgradesPerLevel;
-            }
-            if (other.AllowedLevelsAbovePlayer != 0)
-            {
-                AllowedLevelsAbovePlayer = other.AllowedLevelsAbovePlayer;
-            }
-            candyCost_.Add(other.candyCost_);
-            stardustCost_.Add(other.stardustCost_);
-        }
-
-        public void MergeFrom(pb::CodedInputStream input)
-        {
-            uint tag;
-            while ((tag = input.ReadTag()) != 0)
-            {
-                switch (tag)
-                {
-                    default:
-                        input.SkipLastField();
-                        break;
-                    case 8:
-                        {
-                            UpgradesPerLevel = input.ReadInt32();
-                            break;
-                        }
-                    case 16:
-                        {
-                            AllowedLevelsAbovePlayer = input.ReadInt32();
-                            break;
-                        }
-                    case 26:
-                    case 24:
-                        {
-                            candyCost_.AddEntriesFrom(input, _repeated_candyCost_codec);
-                            break;
-                        }
-                    case 34:
-                    case 32:
-                        {
-                            stardustCost_.AddEntriesFrom(input, _repeated_stardustCost_codec);
-                            break;
-                        }
-                }
-            }
-        }
-
-        public override bool Equals(object other)
-        {
-            return Equals(other as PokemonUpgradeSettings);
-        }
-
-        public override int GetHashCode()
-        {
-            var hash = 1;
-            if (UpgradesPerLevel != 0) hash ^= UpgradesPerLevel.GetHashCode();
-            if (AllowedLevelsAbovePlayer != 0) hash ^= AllowedLevelsAbovePlayer.GetHashCode();
-            hash ^= candyCost_.GetHashCode();
-            hash ^= stardustCost_.GetHashCode();
-            return hash;
-        }
-
-        partial void OnConstruction();
-
-        public override string ToString()
-        {
-            return pb::JsonFormatter.ToDiagnosticString(this);
-        }
-    }
-
-    [global::System.Diagnostics.DebuggerNonUserCodeAttribute()]
-    public sealed partial class IapSettings : pb::IMessage<IapSettings>
-    {
-        /// <summary>Field number for the "daily_bonus_coins" field.</summary>
-        public const int DailyBonusCoinsFieldNumber = 1;
-
-        /// <summary>Field number for the "daily_defender_bonus_per_pokemon" field.</summary>
-        public const int DailyDefenderBonusPerPokemonFieldNumber = 2;
-
-        /// <summary>Field number for the "daily_defender_bonus_max_defenders" field.</summary>
-        public const int DailyDefenderBonusMaxDefendersFieldNumber = 3;
-
-        /// <summary>Field number for the "daily_defender_bonus_currency" field.</summary>
-        public const int DailyDefenderBonusCurrencyFieldNumber = 4;
-
-        /// <summary>Field number for the "min_time_between_claims_ms" field.</summary>
-        public const int MinTimeBetweenClaimsMsFieldNumber = 5;
-
-        /// <summary>Field number for the "daily_bonus_enabled" field.</summary>
-        public const int DailyBonusEnabledFieldNumber = 6;
-
-        /// <summary>Field number for the "daily_defender_bonus_enabled" field.</summary>
-        public const int DailyDefenderBonusEnabledFieldNumber = 7;
-
-        private static readonly pb::MessageParser<IapSettings> _parser =
-            new pb::MessageParser<IapSettings>(() => new IapSettings());
-
-        private static readonly pb::FieldCodec<int> _repeated_dailyDefenderBonusPerPokemon_codec
-            = pb::FieldCodec.ForInt32(18);
-
-        private static readonly pb::FieldCodec<string> _repeated_dailyDefenderBonusCurrency_codec
-            = pb::FieldCodec.ForString(34);
-
-        private readonly pbc::RepeatedField<string> dailyDefenderBonusCurrency_ = new pbc::RepeatedField<string>();
-        private readonly pbc::RepeatedField<int> dailyDefenderBonusPerPokemon_ = new pbc::RepeatedField<int>();
-        private int dailyBonusCoins_;
-        private bool dailyBonusEnabled_;
-        private bool dailyDefenderBonusEnabled_;
-        private int dailyDefenderBonusMaxDefenders_;
-        private long minTimeBetweenClaimsMs_;
-
-        public IapSettings()
-        {
-            OnConstruction();
-        }
-
-        public IapSettings(IapSettings other) : this()
-        {
-            dailyBonusCoins_ = other.dailyBonusCoins_;
-            dailyDefenderBonusPerPokemon_ = other.dailyDefenderBonusPerPokemon_.Clone();
-            dailyDefenderBonusMaxDefenders_ = other.dailyDefenderBonusMaxDefenders_;
-            dailyDefenderBonusCurrency_ = other.dailyDefenderBonusCurrency_.Clone();
-            minTimeBetweenClaimsMs_ = other.minTimeBetweenClaimsMs_;
-            dailyBonusEnabled_ = other.dailyBonusEnabled_;
-            dailyDefenderBonusEnabled_ = other.dailyDefenderBonusEnabled_;
-        }
-
-        public static pb::MessageParser<IapSettings> Parser
-        {
-            get { return _parser; }
-        }
-
-        public static pbr::MessageDescriptor Descriptor
-        {
-            get { return global::PokemonGo.RocketAPI.GeneratedCode.PayloadsReflection.Descriptor.MessageTypes[68]; }
-        }
-
-        public int DailyBonusCoins
-        {
-            get { return dailyBonusCoins_; }
-            set { dailyBonusCoins_ = value; }
-        }
-
-        public pbc::RepeatedField<int> DailyDefenderBonusPerPokemon
-        {
-            get { return dailyDefenderBonusPerPokemon_; }
-        }
-
-        public int DailyDefenderBonusMaxDefenders
-        {
-            get { return dailyDefenderBonusMaxDefenders_; }
-            set { dailyDefenderBonusMaxDefenders_ = value; }
-        }
-
-        public pbc::RepeatedField<string> DailyDefenderBonusCurrency
-        {
-            get { return dailyDefenderBonusCurrency_; }
-        }
-
-        public long MinTimeBetweenClaimsMs
-        {
-            get { return minTimeBetweenClaimsMs_; }
-            set { minTimeBetweenClaimsMs_ = value; }
-        }
-
-        public bool DailyBonusEnabled
-        {
-            get { return dailyBonusEnabled_; }
-            set { dailyBonusEnabled_ = value; }
-        }
-
-        public bool DailyDefenderBonusEnabled
-        {
-            get { return dailyDefenderBonusEnabled_; }
-            set { dailyDefenderBonusEnabled_ = value; }
-        }
-
-        pbr::MessageDescriptor pb::IMessage.Descriptor
-        {
-            get { return Descriptor; }
-        }
-
-        public IapSettings Clone()
-        {
-            return new IapSettings(this);
-        }
-
-        public bool Equals(IapSettings other)
-        {
-            if (ReferenceEquals(other, null))
-            {
-                return false;
-            }
-            if (ReferenceEquals(other, this))
-            {
-                return true;
-            }
-            if (DailyBonusCoins != other.DailyBonusCoins) return false;
-            if (!dailyDefenderBonusPerPokemon_.Equals(other.dailyDefenderBonusPerPokemon_)) return false;
-            if (DailyDefenderBonusMaxDefenders != other.DailyDefenderBonusMaxDefenders) return false;
-            if (!dailyDefenderBonusCurrency_.Equals(other.dailyDefenderBonusCurrency_)) return false;
-            if (MinTimeBetweenClaimsMs != other.MinTimeBetweenClaimsMs) return false;
-            if (DailyBonusEnabled != other.DailyBonusEnabled) return false;
-            if (DailyDefenderBonusEnabled != other.DailyDefenderBonusEnabled) return false;
-            return true;
-        }
-
-        public void WriteTo(pb::CodedOutputStream output)
-        {
-            if (DailyBonusCoins != 0)
-            {
-                output.WriteRawTag(8);
-                output.WriteInt32(DailyBonusCoins);
-            }
-            dailyDefenderBonusPerPokemon_.WriteTo(output, _repeated_dailyDefenderBonusPerPokemon_codec);
-            if (DailyDefenderBonusMaxDefenders != 0)
-            {
-                output.WriteRawTag(24);
-                output.WriteInt32(DailyDefenderBonusMaxDefenders);
-            }
-            dailyDefenderBonusCurrency_.WriteTo(output, _repeated_dailyDefenderBonusCurrency_codec);
-            if (MinTimeBetweenClaimsMs != 0L)
-            {
-                output.WriteRawTag(40);
-                output.WriteInt64(MinTimeBetweenClaimsMs);
-            }
-            if (DailyBonusEnabled != false)
-            {
-                output.WriteRawTag(48);
-                output.WriteBool(DailyBonusEnabled);
-            }
-            if (DailyDefenderBonusEnabled != false)
-            {
-                output.WriteRawTag(56);
-                output.WriteBool(DailyDefenderBonusEnabled);
-            }
-        }
-
-        public int CalculateSize()
-        {
-            var size = 0;
-            if (DailyBonusCoins != 0)
-            {
-                size += 1 + pb::CodedOutputStream.ComputeInt32Size(DailyBonusCoins);
-            }
-            size += dailyDefenderBonusPerPokemon_.CalculateSize(_repeated_dailyDefenderBonusPerPokemon_codec);
-            if (DailyDefenderBonusMaxDefenders != 0)
-            {
-                size += 1 + pb::CodedOutputStream.ComputeInt32Size(DailyDefenderBonusMaxDefenders);
-            }
-            size += dailyDefenderBonusCurrency_.CalculateSize(_repeated_dailyDefenderBonusCurrency_codec);
-            if (MinTimeBetweenClaimsMs != 0L)
-            {
-                size += 1 + pb::CodedOutputStream.ComputeInt64Size(MinTimeBetweenClaimsMs);
-            }
-            if (DailyBonusEnabled != false)
-            {
-                size += 1 + 1;
-            }
-            if (DailyDefenderBonusEnabled != false)
-            {
-                size += 1 + 1;
-            }
-            return size;
-        }
-
-        public void MergeFrom(IapSettings other)
-        {
-            if (other == null)
-            {
-                return;
-            }
-            if (other.DailyBonusCoins != 0)
-            {
-                DailyBonusCoins = other.DailyBonusCoins;
-            }
-            dailyDefenderBonusPerPokemon_.Add(other.dailyDefenderBonusPerPokemon_);
-            if (other.DailyDefenderBonusMaxDefenders != 0)
-            {
-                DailyDefenderBonusMaxDefenders = other.DailyDefenderBonusMaxDefenders;
-            }
-            dailyDefenderBonusCurrency_.Add(other.dailyDefenderBonusCurrency_);
-            if (other.MinTimeBetweenClaimsMs != 0L)
-            {
-                MinTimeBetweenClaimsMs = other.MinTimeBetweenClaimsMs;
-            }
-            if (other.DailyBonusEnabled != false)
-            {
-                DailyBonusEnabled = other.DailyBonusEnabled;
-            }
-            if (other.DailyDefenderBonusEnabled != false)
-            {
-                DailyDefenderBonusEnabled = other.DailyDefenderBonusEnabled;
-            }
-        }
-
-        public void MergeFrom(pb::CodedInputStream input)
-        {
-            uint tag;
-            while ((tag = input.ReadTag()) != 0)
-            {
-                switch (tag)
-                {
-                    default:
-                        input.SkipLastField();
-                        break;
-                    case 8:
-                        {
-                            DailyBonusCoins = input.ReadInt32();
-                            break;
-                        }
-                    case 18:
-                    case 16:
-                        {
-                            dailyDefenderBonusPerPokemon_.AddEntriesFrom(input, _repeated_dailyDefenderBonusPerPokemon_codec);
-                            break;
-                        }
-                    case 24:
-                        {
-                            DailyDefenderBonusMaxDefenders = input.ReadInt32();
-                            break;
-                        }
-                    case 34:
-                        {
-                            dailyDefenderBonusCurrency_.AddEntriesFrom(input, _repeated_dailyDefenderBonusCurrency_codec);
-                            break;
-                        }
-                    case 40:
-                        {
-                            MinTimeBetweenClaimsMs = input.ReadInt64();
-                            break;
-                        }
-                    case 48:
-                        {
-                            DailyBonusEnabled = input.ReadBool();
-                            break;
-                        }
-                    case 56:
-                        {
-                            DailyDefenderBonusEnabled = input.ReadBool();
-                            break;
-                        }
-                }
-            }
-        }
-
-        public override bool Equals(object other)
-        {
-            return Equals(other as IapSettings);
-        }
-
-        public override int GetHashCode()
-        {
-            var hash = 1;
-            if (DailyBonusCoins != 0) hash ^= DailyBonusCoins.GetHashCode();
-            hash ^= dailyDefenderBonusPerPokemon_.GetHashCode();
-            if (DailyDefenderBonusMaxDefenders != 0) hash ^= DailyDefenderBonusMaxDefenders.GetHashCode();
-            hash ^= dailyDefenderBonusCurrency_.GetHashCode();
-            if (MinTimeBetweenClaimsMs != 0L) hash ^= MinTimeBetweenClaimsMs.GetHashCode();
-            if (DailyBonusEnabled != false) hash ^= DailyBonusEnabled.GetHashCode();
-            if (DailyDefenderBonusEnabled != false) hash ^= DailyDefenderBonusEnabled.GetHashCode();
-            return hash;
-        }
-
-        partial void OnConstruction();
-
-        public override string ToString()
-        {
-            return pb::JsonFormatter.ToDiagnosticString(this);
-        }
-    }
-
-    [global::System.Diagnostics.DebuggerNonUserCodeAttribute()]
-    public sealed partial class IapItemDisplay : pb::IMessage<IapItemDisplay>
-    {
-        /// <summary>Field number for the "sku" field.</summary>
-        public const int SkuFieldNumber = 1;
-
-        /// <summary>Field number for the "category" field.</summary>
-        public const int CategoryFieldNumber = 2;
-
-        /// <summary>Field number for the "sort_order" field.</summary>
-        public const int SortOrderFieldNumber = 3;
-
-        /// <summary>Field number for the "item_ids" field.</summary>
-        public const int ItemIdsFieldNumber = 4;
-
-        /// <summary>Field number for the "counts" field.</summary>
-        public const int CountsFieldNumber = 5;
-
-        private static readonly pb::MessageParser<IapItemDisplay> _parser =
-            new pb::MessageParser<IapItemDisplay>(() => new IapItemDisplay());
-
-        private static readonly pb::FieldCodec<global::PokemonGo.RocketAPI.GeneratedCode.ItemId> _repeated_itemIds_codec
-            = pb::FieldCodec.ForEnum(34, x => (int)x, x => (global::PokemonGo.RocketAPI.GeneratedCode.ItemId)x);
-
-        private static readonly pb::FieldCodec<int> _repeated_counts_codec
-            = pb::FieldCodec.ForInt32(42);
-
-        private readonly pbc::RepeatedField<int> counts_ = new pbc::RepeatedField<int>();
-
-        private readonly pbc::RepeatedField<global::PokemonGo.RocketAPI.GeneratedCode.ItemId> itemIds_ =
-            new pbc::RepeatedField<global::PokemonGo.RocketAPI.GeneratedCode.ItemId>();
-
-        private global::PokemonGo.RocketAPI.GeneratedCode.HoloIapItemCategory category_ = 0;
-        private string sku_ = "";
-        private int sortOrder_;
-
-        public IapItemDisplay()
-        {
-            OnConstruction();
-        }
-
-        public IapItemDisplay(IapItemDisplay other) : this()
-        {
-            sku_ = other.sku_;
-            category_ = other.category_;
-            sortOrder_ = other.sortOrder_;
-            itemIds_ = other.itemIds_.Clone();
-            counts_ = other.counts_.Clone();
-        }
-
-        public static pb::MessageParser<IapItemDisplay> Parser
-        {
-            get { return _parser; }
-        }
-
-        public static pbr::MessageDescriptor Descriptor
-        {
-            get { return global::PokemonGo.RocketAPI.GeneratedCode.PayloadsReflection.Descriptor.MessageTypes[69]; }
-        }
-
-        public string Sku
-        {
-            get { return sku_; }
-            set { sku_ = pb::ProtoPreconditions.CheckNotNull(value, "value"); }
-        }
-
-        public global::PokemonGo.RocketAPI.GeneratedCode.HoloIapItemCategory Category
-        {
-            get { return category_; }
-            set { category_ = value; }
-        }
-
-        public int SortOrder
-        {
-            get { return sortOrder_; }
-            set { sortOrder_ = value; }
-        }
-
-        public pbc::RepeatedField<global::PokemonGo.RocketAPI.GeneratedCode.ItemId> ItemIds
-        {
-            get { return itemIds_; }
-        }
-
-        public pbc::RepeatedField<int> Counts
-        {
-            get { return counts_; }
-        }
-
-        pbr::MessageDescriptor pb::IMessage.Descriptor
-        {
-            get { return Descriptor; }
-        }
-
-        public IapItemDisplay Clone()
-        {
-            return new IapItemDisplay(this);
-        }
-
-        public bool Equals(IapItemDisplay other)
-        {
-            if (ReferenceEquals(other, null))
-            {
-                return false;
-            }
-            if (ReferenceEquals(other, this))
-            {
-                return true;
-            }
-            if (Sku != other.Sku) return false;
-            if (Category != other.Category) return false;
-            if (SortOrder != other.SortOrder) return false;
-            if (!itemIds_.Equals(other.itemIds_)) return false;
-            if (!counts_.Equals(other.counts_)) return false;
-            return true;
-        }
-
-        public void WriteTo(pb::CodedOutputStream output)
-        {
-            if (Sku.Length != 0)
-            {
-                output.WriteRawTag(10);
-                output.WriteString(Sku);
-            }
-            if (Category != 0)
-            {
-                output.WriteRawTag(16);
-                output.WriteEnum((int)Category);
-            }
-            if (SortOrder != 0)
-            {
-                output.WriteRawTag(24);
-                output.WriteInt32(SortOrder);
-            }
-            itemIds_.WriteTo(output, _repeated_itemIds_codec);
-            counts_.WriteTo(output, _repeated_counts_codec);
-        }
-
-        public int CalculateSize()
-        {
-            var size = 0;
-            if (Sku.Length != 0)
-            {
-                size += 1 + pb::CodedOutputStream.ComputeStringSize(Sku);
-            }
-            if (Category != 0)
-            {
-                size += 1 + pb::CodedOutputStream.ComputeEnumSize((int)Category);
-            }
-            if (SortOrder != 0)
-            {
-                size += 1 + pb::CodedOutputStream.ComputeInt32Size(SortOrder);
-            }
-            size += itemIds_.CalculateSize(_repeated_itemIds_codec);
-            size += counts_.CalculateSize(_repeated_counts_codec);
-            return size;
-        }
-
-        public void MergeFrom(IapItemDisplay other)
-        {
-            if (other == null)
-            {
-                return;
-            }
-            if (other.Sku.Length != 0)
-            {
-                Sku = other.Sku;
-            }
-            if (other.Category != 0)
-            {
-                Category = other.Category;
-            }
-            if (other.SortOrder != 0)
-            {
-                SortOrder = other.SortOrder;
-            }
-            itemIds_.Add(other.itemIds_);
-            counts_.Add(other.counts_);
-        }
-
-        public void MergeFrom(pb::CodedInputStream input)
-        {
-            uint tag;
-            while ((tag = input.ReadTag()) != 0)
-            {
-                switch (tag)
-                {
-                    default:
-                        input.SkipLastField();
-                        break;
-                    case 10:
-                        {
-                            Sku = input.ReadString();
-                            break;
-                        }
-                    case 16:
-                        {
-                            category_ = (global::PokemonGo.RocketAPI.GeneratedCode.HoloIapItemCategory)input.ReadEnum();
-                            break;
-                        }
-                    case 24:
-                        {
-                            SortOrder = input.ReadInt32();
-                            break;
-                        }
-                    case 34:
-                    case 32:
-                        {
-                            itemIds_.AddEntriesFrom(input, _repeated_itemIds_codec);
-                            break;
-                        }
-                    case 42:
-                    case 40:
-                        {
-                            counts_.AddEntriesFrom(input, _repeated_counts_codec);
-                            break;
-                        }
-                }
-            }
-        }
-
-        public override bool Equals(object other)
-        {
-            return Equals(other as IapItemDisplay);
-        }
-
-        public override int GetHashCode()
-        {
-            var hash = 1;
-            if (Sku.Length != 0) hash ^= Sku.GetHashCode();
-            if (Category != 0) hash ^= Category.GetHashCode();
-            if (SortOrder != 0) hash ^= SortOrder.GetHashCode();
-            hash ^= itemIds_.GetHashCode();
-            hash ^= counts_.GetHashCode();
-            return hash;
-        }
-
-        partial void OnConstruction();
-
-        public override string ToString()
-        {
-            return pb::JsonFormatter.ToDiagnosticString(this);
-        }
-    }
-
-    [global::System.Diagnostics.DebuggerNonUserCodeAttribute()]
-    public sealed partial class EncounterSettings : pb::IMessage<EncounterSettings>
-    {
-        /// <summary>Field number for the "spin_bonus_threshold" field.</summary>
-        public const int SpinBonusThresholdFieldNumber = 1;
-
-        /// <summary>Field number for the "excellent_throw_threshold" field.</summary>
-        public const int ExcellentThrowThresholdFieldNumber = 2;
-
-        /// <summary>Field number for the "great_throw_threshold" field.</summary>
-        public const int GreatThrowThresholdFieldNumber = 3;
-
-        /// <summary>Field number for the "nice_throw_threshold" field.</summary>
-        public const int NiceThrowThresholdFieldNumber = 4;
-
-        /// <summary>Field number for the "milestone_threshold" field.</summary>
-        public const int MilestoneThresholdFieldNumber = 5;
-
-        private static readonly pb::MessageParser<EncounterSettings> _parser =
-            new pb::MessageParser<EncounterSettings>(() => new EncounterSettings());
-
-        private float excellentThrowThreshold_;
-        private float greatThrowThreshold_;
-        private int milestoneThreshold_;
-        private float niceThrowThreshold_;
-        private float spinBonusThreshold_;
-
-        public EncounterSettings()
-        {
-            OnConstruction();
-        }
-
-        public EncounterSettings(EncounterSettings other) : this()
-        {
-            spinBonusThreshold_ = other.spinBonusThreshold_;
-            excellentThrowThreshold_ = other.excellentThrowThreshold_;
-            greatThrowThreshold_ = other.greatThrowThreshold_;
-            niceThrowThreshold_ = other.niceThrowThreshold_;
-            milestoneThreshold_ = other.milestoneThreshold_;
-        }
-
-        public static pb::MessageParser<EncounterSettings> Parser
-        {
-            get { return _parser; }
-        }
-
-        public static pbr::MessageDescriptor Descriptor
-        {
-            get { return global::PokemonGo.RocketAPI.GeneratedCode.PayloadsReflection.Descriptor.MessageTypes[70]; }
-        }
-
-        public float SpinBonusThreshold
-        {
-            get { return spinBonusThreshold_; }
-            set { spinBonusThreshold_ = value; }
-        }
-
-        public float ExcellentThrowThreshold
-        {
-            get { return excellentThrowThreshold_; }
-            set { excellentThrowThreshold_ = value; }
-        }
-
-        public float GreatThrowThreshold
-        {
-            get { return greatThrowThreshold_; }
-            set { greatThrowThreshold_ = value; }
-        }
-
-        public float NiceThrowThreshold
-        {
-            get { return niceThrowThreshold_; }
-            set { niceThrowThreshold_ = value; }
-        }
-
-        public int MilestoneThreshold
-        {
-            get { return milestoneThreshold_; }
-            set { milestoneThreshold_ = value; }
-        }
-
-        pbr::MessageDescriptor pb::IMessage.Descriptor
-        {
-            get { return Descriptor; }
-        }
-
-        public EncounterSettings Clone()
-        {
-            return new EncounterSettings(this);
-        }
-
-        public bool Equals(EncounterSettings other)
-        {
-            if (ReferenceEquals(other, null))
-            {
-                return false;
-            }
-            if (ReferenceEquals(other, this))
-            {
-                return true;
-            }
-            if (SpinBonusThreshold != other.SpinBonusThreshold) return false;
-            if (ExcellentThrowThreshold != other.ExcellentThrowThreshold) return false;
-            if (GreatThrowThreshold != other.GreatThrowThreshold) return false;
-            if (NiceThrowThreshold != other.NiceThrowThreshold) return false;
-            if (MilestoneThreshold != other.MilestoneThreshold) return false;
-            return true;
-        }
-
-        public void WriteTo(pb::CodedOutputStream output)
-        {
-            if (SpinBonusThreshold != 0F)
-            {
-                output.WriteRawTag(13);
-                output.WriteFloat(SpinBonusThreshold);
-            }
-            if (ExcellentThrowThreshold != 0F)
-            {
-                output.WriteRawTag(21);
-                output.WriteFloat(ExcellentThrowThreshold);
-            }
-            if (GreatThrowThreshold != 0F)
-            {
-                output.WriteRawTag(29);
-                output.WriteFloat(GreatThrowThreshold);
-            }
-            if (NiceThrowThreshold != 0F)
-            {
-                output.WriteRawTag(37);
-                output.WriteFloat(NiceThrowThreshold);
-            }
-            if (MilestoneThreshold != 0)
-            {
-                output.WriteRawTag(40);
-                output.WriteInt32(MilestoneThreshold);
-            }
-        }
-
-        public int CalculateSize()
-        {
-            var size = 0;
-            if (SpinBonusThreshold != 0F)
-            {
-                size += 1 + 4;
-            }
-            if (ExcellentThrowThreshold != 0F)
-            {
-                size += 1 + 4;
-            }
-            if (GreatThrowThreshold != 0F)
-            {
-                size += 1 + 4;
-            }
-            if (NiceThrowThreshold != 0F)
-            {
-                size += 1 + 4;
-            }
-            if (MilestoneThreshold != 0)
-            {
-                size += 1 + pb::CodedOutputStream.ComputeInt32Size(MilestoneThreshold);
-            }
-            return size;
-        }
-
-        public void MergeFrom(EncounterSettings other)
-        {
-            if (other == null)
-            {
-                return;
-            }
-            if (other.SpinBonusThreshold != 0F)
-            {
-                SpinBonusThreshold = other.SpinBonusThreshold;
-            }
-            if (other.ExcellentThrowThreshold != 0F)
-            {
-                ExcellentThrowThreshold = other.ExcellentThrowThreshold;
-            }
-            if (other.GreatThrowThreshold != 0F)
-            {
-                GreatThrowThreshold = other.GreatThrowThreshold;
-            }
-            if (other.NiceThrowThreshold != 0F)
-            {
-                NiceThrowThreshold = other.NiceThrowThreshold;
-            }
-            if (other.MilestoneThreshold != 0)
-            {
-                MilestoneThreshold = other.MilestoneThreshold;
-            }
-        }
-
-        public void MergeFrom(pb::CodedInputStream input)
-        {
-            uint tag;
-            while ((tag = input.ReadTag()) != 0)
-            {
-                switch (tag)
-                {
-                    default:
-                        input.SkipLastField();
-                        break;
-                    case 13:
-                        {
-                            SpinBonusThreshold = input.ReadFloat();
-                            break;
-                        }
-                    case 21:
-                        {
-                            ExcellentThrowThreshold = input.ReadFloat();
-                            break;
-                        }
-                    case 29:
-                        {
-                            GreatThrowThreshold = input.ReadFloat();
-                            break;
-                        }
-                    case 37:
-                        {
-                            NiceThrowThreshold = input.ReadFloat();
-                            break;
-                        }
-                    case 40:
-                        {
-                            MilestoneThreshold = input.ReadInt32();
-                            break;
-                        }
-                }
-            }
-        }
-
-        public override bool Equals(object other)
-        {
-            return Equals(other as EncounterSettings);
-        }
-
-        public override int GetHashCode()
-        {
-            var hash = 1;
-            if (SpinBonusThreshold != 0F) hash ^= SpinBonusThreshold.GetHashCode();
-            if (ExcellentThrowThreshold != 0F) hash ^= ExcellentThrowThreshold.GetHashCode();
-            if (GreatThrowThreshold != 0F) hash ^= GreatThrowThreshold.GetHashCode();
-            if (NiceThrowThreshold != 0F) hash ^= NiceThrowThreshold.GetHashCode();
-            if (MilestoneThreshold != 0) hash ^= MilestoneThreshold.GetHashCode();
-            return hash;
-        }
-
-        partial void OnConstruction();
-
-        public override string ToString()
-        {
-            return pb::JsonFormatter.ToDiagnosticString(this);
-        }
-    }
-
-    [global::System.Diagnostics.DebuggerNonUserCodeAttribute()]
-    public sealed partial class GymBattleSettings : pb::IMessage<GymBattleSettings>
-    {
-        /// <summary>Field number for the "energy_per_sec" field.</summary>
-        public const int EnergyPerSecFieldNumber = 1;
-
-        /// <summary>Field number for the "dodge_energy_cost" field.</summary>
-        public const int DodgeEnergyCostFieldNumber = 2;
-
-        /// <summary>Field number for the "retarget_seconds" field.</summary>
-        public const int RetargetSecondsFieldNumber = 3;
-
-        /// <summary>Field number for the "enemy_attack_interval" field.</summary>
-        public const int EnemyAttackIntervalFieldNumber = 4;
-
-        /// <summary>Field number for the "attack_server_interval" field.</summary>
-        public const int AttackServerIntervalFieldNumber = 5;
-
-        /// <summary>Field number for the "round_duration_seconds" field.</summary>
-        public const int RoundDurationSecondsFieldNumber = 6;
-
-        /// <summary>Field number for the "bonus_time_per_ally_seconds" field.</summary>
-        public const int BonusTimePerAllySecondsFieldNumber = 7;
-
-        /// <summary>Field number for the "maximum_attackers_per_battle" field.</summary>
-        public const int MaximumAttackersPerBattleFieldNumber = 8;
-
-        /// <summary>Field number for the "same_type_attack_bonus_multiplier" field.</summary>
-        public const int SameTypeAttackBonusMultiplierFieldNumber = 9;
-
-        /// <summary>Field number for the "maximum_energy" field.</summary>
-        public const int MaximumEnergyFieldNumber = 10;
-
-        /// <summary>Field number for the "energy_delta_per_health_lost" field.</summary>
-        public const int EnergyDeltaPerHealthLostFieldNumber = 11;
-
-        /// <summary>Field number for the "dodge_duration_ms" field.</summary>
-        public const int DodgeDurationMsFieldNumber = 12;
-
-        /// <summary>Field number for the "minimum_player_level" field.</summary>
-        public const int MinimumPlayerLevelFieldNumber = 13;
-
-        /// <summary>Field number for the "swap_duration_ms" field.</summary>
-        public const int SwapDurationMsFieldNumber = 14;
-
-        private static readonly pb::MessageParser<GymBattleSettings> _parser =
-            new pb::MessageParser<GymBattleSettings>(() => new GymBattleSettings());
-
-        private float attackServerInterval_;
-        private float bonusTimePerAllySeconds_;
-        private int dodgeDurationMs_;
-        private float dodgeEnergyCost_;
-        private float enemyAttackInterval_;
-        private float energyDeltaPerHealthLost_;
-        private float energyPerSec_;
-        private int maximumAttackersPerBattle_;
-        private int maximumEnergy_;
-        private int minimumPlayerLevel_;
-        private float retargetSeconds_;
-        private float roundDurationSeconds_;
-        private float sameTypeAttackBonusMultiplier_;
-        private int swapDurationMs_;
-
-        public GymBattleSettings()
-        {
-            OnConstruction();
-        }
-
-        public GymBattleSettings(GymBattleSettings other) : this()
-        {
-            energyPerSec_ = other.energyPerSec_;
-            dodgeEnergyCost_ = other.dodgeEnergyCost_;
-            retargetSeconds_ = other.retargetSeconds_;
-            enemyAttackInterval_ = other.enemyAttackInterval_;
-            attackServerInterval_ = other.attackServerInterval_;
-            roundDurationSeconds_ = other.roundDurationSeconds_;
-            bonusTimePerAllySeconds_ = other.bonusTimePerAllySeconds_;
-            maximumAttackersPerBattle_ = other.maximumAttackersPerBattle_;
-            sameTypeAttackBonusMultiplier_ = other.sameTypeAttackBonusMultiplier_;
-            maximumEnergy_ = other.maximumEnergy_;
-            energyDeltaPerHealthLost_ = other.energyDeltaPerHealthLost_;
-            dodgeDurationMs_ = other.dodgeDurationMs_;
-            minimumPlayerLevel_ = other.minimumPlayerLevel_;
-            swapDurationMs_ = other.swapDurationMs_;
-        }
-
-        public static pb::MessageParser<GymBattleSettings> Parser
-        {
-            get { return _parser; }
-        }
-
-        public static pbr::MessageDescriptor Descriptor
-        {
-            get { return global::PokemonGo.RocketAPI.GeneratedCode.PayloadsReflection.Descriptor.MessageTypes[71]; }
-        }
-
-        public float EnergyPerSec
-        {
-            get { return energyPerSec_; }
-            set { energyPerSec_ = value; }
-        }
-
-        public float DodgeEnergyCost
-        {
-            get { return dodgeEnergyCost_; }
-            set { dodgeEnergyCost_ = value; }
-        }
-
-        public float RetargetSeconds
-        {
-            get { return retargetSeconds_; }
-            set { retargetSeconds_ = value; }
-        }
-
-        public float EnemyAttackInterval
-        {
-            get { return enemyAttackInterval_; }
-            set { enemyAttackInterval_ = value; }
-        }
-
-        public float AttackServerInterval
-        {
-            get { return attackServerInterval_; }
-            set { attackServerInterval_ = value; }
-        }
-
-        public float RoundDurationSeconds
-        {
-            get { return roundDurationSeconds_; }
-            set { roundDurationSeconds_ = value; }
-        }
-
-        public float BonusTimePerAllySeconds
-        {
-            get { return bonusTimePerAllySeconds_; }
-            set { bonusTimePerAllySeconds_ = value; }
-        }
-
-        public int MaximumAttackersPerBattle
-        {
-            get { return maximumAttackersPerBattle_; }
-            set { maximumAttackersPerBattle_ = value; }
-        }
-
-        public float SameTypeAttackBonusMultiplier
-        {
-            get { return sameTypeAttackBonusMultiplier_; }
-            set { sameTypeAttackBonusMultiplier_ = value; }
-        }
-
-        public int MaximumEnergy
-        {
-            get { return maximumEnergy_; }
-            set { maximumEnergy_ = value; }
-        }
-
-        public float EnergyDeltaPerHealthLost
-        {
-            get { return energyDeltaPerHealthLost_; }
-            set { energyDeltaPerHealthLost_ = value; }
-        }
-
-        public int DodgeDurationMs
-        {
-            get { return dodgeDurationMs_; }
-            set { dodgeDurationMs_ = value; }
-        }
-
-        public int MinimumPlayerLevel
-        {
-            get { return minimumPlayerLevel_; }
-            set { minimumPlayerLevel_ = value; }
-        }
-
-        public int SwapDurationMs
-        {
-            get { return swapDurationMs_; }
-            set { swapDurationMs_ = value; }
-        }
-
-        pbr::MessageDescriptor pb::IMessage.Descriptor
-        {
-            get { return Descriptor; }
-        }
-
-        public GymBattleSettings Clone()
-        {
-            return new GymBattleSettings(this);
-        }
-
-        public bool Equals(GymBattleSettings other)
-        {
-            if (ReferenceEquals(other, null))
-            {
-                return false;
-            }
-            if (ReferenceEquals(other, this))
-            {
-                return true;
-            }
-            if (EnergyPerSec != other.EnergyPerSec) return false;
-            if (DodgeEnergyCost != other.DodgeEnergyCost) return false;
-            if (RetargetSeconds != other.RetargetSeconds) return false;
-            if (EnemyAttackInterval != other.EnemyAttackInterval) return false;
-            if (AttackServerInterval != other.AttackServerInterval) return false;
-            if (RoundDurationSeconds != other.RoundDurationSeconds) return false;
-            if (BonusTimePerAllySeconds != other.BonusTimePerAllySeconds) return false;
-            if (MaximumAttackersPerBattle != other.MaximumAttackersPerBattle) return false;
-            if (SameTypeAttackBonusMultiplier != other.SameTypeAttackBonusMultiplier) return false;
-            if (MaximumEnergy != other.MaximumEnergy) return false;
-            if (EnergyDeltaPerHealthLost != other.EnergyDeltaPerHealthLost) return false;
-            if (DodgeDurationMs != other.DodgeDurationMs) return false;
-            if (MinimumPlayerLevel != other.MinimumPlayerLevel) return false;
-            if (SwapDurationMs != other.SwapDurationMs) return false;
-            return true;
-        }
-
-        public void WriteTo(pb::CodedOutputStream output)
-        {
-            if (EnergyPerSec != 0F)
-            {
-                output.WriteRawTag(13);
-                output.WriteFloat(EnergyPerSec);
-            }
-            if (DodgeEnergyCost != 0F)
-            {
-                output.WriteRawTag(21);
-                output.WriteFloat(DodgeEnergyCost);
-            }
-            if (RetargetSeconds != 0F)
-            {
-                output.WriteRawTag(29);
-                output.WriteFloat(RetargetSeconds);
-            }
-            if (EnemyAttackInterval != 0F)
-            {
-                output.WriteRawTag(37);
-                output.WriteFloat(EnemyAttackInterval);
-            }
-            if (AttackServerInterval != 0F)
-            {
-                output.WriteRawTag(45);
-                output.WriteFloat(AttackServerInterval);
-            }
-            if (RoundDurationSeconds != 0F)
-            {
-                output.WriteRawTag(53);
-                output.WriteFloat(RoundDurationSeconds);
-            }
-            if (BonusTimePerAllySeconds != 0F)
-            {
-                output.WriteRawTag(61);
-                output.WriteFloat(BonusTimePerAllySeconds);
-            }
-            if (MaximumAttackersPerBattle != 0)
-            {
-                output.WriteRawTag(64);
-                output.WriteInt32(MaximumAttackersPerBattle);
-            }
-            if (SameTypeAttackBonusMultiplier != 0F)
-            {
-                output.WriteRawTag(77);
-                output.WriteFloat(SameTypeAttackBonusMultiplier);
-            }
-            if (MaximumEnergy != 0)
-            {
-                output.WriteRawTag(80);
-                output.WriteInt32(MaximumEnergy);
-            }
-            if (EnergyDeltaPerHealthLost != 0F)
-            {
-                output.WriteRawTag(93);
-                output.WriteFloat(EnergyDeltaPerHealthLost);
-            }
-            if (DodgeDurationMs != 0)
-            {
-                output.WriteRawTag(96);
-                output.WriteInt32(DodgeDurationMs);
-            }
-            if (MinimumPlayerLevel != 0)
-            {
-                output.WriteRawTag(104);
-                output.WriteInt32(MinimumPlayerLevel);
-            }
-            if (SwapDurationMs != 0)
-            {
-                output.WriteRawTag(112);
-                output.WriteInt32(SwapDurationMs);
-            }
-        }
-
-        public int CalculateSize()
-        {
-            var size = 0;
-            if (EnergyPerSec != 0F)
-            {
-                size += 1 + 4;
-            }
-            if (DodgeEnergyCost != 0F)
-            {
-                size += 1 + 4;
-            }
-            if (RetargetSeconds != 0F)
-            {
-                size += 1 + 4;
-            }
-            if (EnemyAttackInterval != 0F)
-            {
-                size += 1 + 4;
-            }
-            if (AttackServerInterval != 0F)
-            {
-                size += 1 + 4;
-            }
-            if (RoundDurationSeconds != 0F)
-            {
-                size += 1 + 4;
-            }
-            if (BonusTimePerAllySeconds != 0F)
-            {
-                size += 1 + 4;
-            }
-            if (MaximumAttackersPerBattle != 0)
-            {
-                size += 1 + pb::CodedOutputStream.ComputeInt32Size(MaximumAttackersPerBattle);
-            }
-            if (SameTypeAttackBonusMultiplier != 0F)
-            {
-                size += 1 + 4;
-            }
-            if (MaximumEnergy != 0)
-            {
-                size += 1 + pb::CodedOutputStream.ComputeInt32Size(MaximumEnergy);
-            }
-            if (EnergyDeltaPerHealthLost != 0F)
-            {
-                size += 1 + 4;
-            }
-            if (DodgeDurationMs != 0)
-            {
-                size += 1 + pb::CodedOutputStream.ComputeInt32Size(DodgeDurationMs);
-            }
-            if (MinimumPlayerLevel != 0)
-            {
-                size += 1 + pb::CodedOutputStream.ComputeInt32Size(MinimumPlayerLevel);
-            }
-            if (SwapDurationMs != 0)
-            {
-                size += 1 + pb::CodedOutputStream.ComputeInt32Size(SwapDurationMs);
-            }
-            return size;
-        }
-
-        public void MergeFrom(GymBattleSettings other)
-        {
-            if (other == null)
-            {
-                return;
-            }
-            if (other.EnergyPerSec != 0F)
-            {
-                EnergyPerSec = other.EnergyPerSec;
-            }
-            if (other.DodgeEnergyCost != 0F)
-            {
-                DodgeEnergyCost = other.DodgeEnergyCost;
-            }
-            if (other.RetargetSeconds != 0F)
-            {
-                RetargetSeconds = other.RetargetSeconds;
-            }
-            if (other.EnemyAttackInterval != 0F)
-            {
-                EnemyAttackInterval = other.EnemyAttackInterval;
-            }
-            if (other.AttackServerInterval != 0F)
-            {
-                AttackServerInterval = other.AttackServerInterval;
-            }
-            if (other.RoundDurationSeconds != 0F)
-            {
-                RoundDurationSeconds = other.RoundDurationSeconds;
-            }
-            if (other.BonusTimePerAllySeconds != 0F)
-            {
-                BonusTimePerAllySeconds = other.BonusTimePerAllySeconds;
-            }
-            if (other.MaximumAttackersPerBattle != 0)
-            {
-                MaximumAttackersPerBattle = other.MaximumAttackersPerBattle;
-            }
-            if (other.SameTypeAttackBonusMultiplier != 0F)
-            {
-                SameTypeAttackBonusMultiplier = other.SameTypeAttackBonusMultiplier;
-            }
-            if (other.MaximumEnergy != 0)
-            {
-                MaximumEnergy = other.MaximumEnergy;
-            }
-            if (other.EnergyDeltaPerHealthLost != 0F)
-            {
-                EnergyDeltaPerHealthLost = other.EnergyDeltaPerHealthLost;
-            }
-            if (other.DodgeDurationMs != 0)
-            {
-                DodgeDurationMs = other.DodgeDurationMs;
-            }
-            if (other.MinimumPlayerLevel != 0)
-            {
-                MinimumPlayerLevel = other.MinimumPlayerLevel;
-            }
-            if (other.SwapDurationMs != 0)
-            {
-                SwapDurationMs = other.SwapDurationMs;
-            }
-        }
-
-        public void MergeFrom(pb::CodedInputStream input)
-        {
-            uint tag;
-            while ((tag = input.ReadTag()) != 0)
-            {
-                switch (tag)
-                {
-                    default:
-                        input.SkipLastField();
-                        break;
-                    case 13:
-                        {
-                            EnergyPerSec = input.ReadFloat();
-                            break;
-                        }
-                    case 21:
-                        {
-                            DodgeEnergyCost = input.ReadFloat();
-                            break;
-                        }
-                    case 29:
-                        {
-                            RetargetSeconds = input.ReadFloat();
-                            break;
-                        }
-                    case 37:
-                        {
-                            EnemyAttackInterval = input.ReadFloat();
-                            break;
-                        }
-                    case 45:
-                        {
-                            AttackServerInterval = input.ReadFloat();
-                            break;
-                        }
-                    case 53:
-                        {
-                            RoundDurationSeconds = input.ReadFloat();
-                            break;
-                        }
-                    case 61:
-                        {
-                            BonusTimePerAllySeconds = input.ReadFloat();
-                            break;
-                        }
-                    case 64:
-                        {
-                            MaximumAttackersPerBattle = input.ReadInt32();
-                            break;
-                        }
-                    case 77:
-                        {
-                            SameTypeAttackBonusMultiplier = input.ReadFloat();
-                            break;
-                        }
-                    case 80:
-                        {
-                            MaximumEnergy = input.ReadInt32();
-                            break;
-                        }
-                    case 93:
-                        {
-                            EnergyDeltaPerHealthLost = input.ReadFloat();
-                            break;
-                        }
-                    case 96:
-                        {
-                            DodgeDurationMs = input.ReadInt32();
-                            break;
-                        }
-                    case 104:
-                        {
-                            MinimumPlayerLevel = input.ReadInt32();
-                            break;
-                        }
-                    case 112:
-                        {
-                            SwapDurationMs = input.ReadInt32();
-                            break;
-                        }
-                }
-            }
-        }
-
-        public override bool Equals(object other)
-        {
-            return Equals(other as GymBattleSettings);
-        }
-
-        public override int GetHashCode()
-        {
-            var hash = 1;
-            if (EnergyPerSec != 0F) hash ^= EnergyPerSec.GetHashCode();
-            if (DodgeEnergyCost != 0F) hash ^= DodgeEnergyCost.GetHashCode();
-            if (RetargetSeconds != 0F) hash ^= RetargetSeconds.GetHashCode();
-            if (EnemyAttackInterval != 0F) hash ^= EnemyAttackInterval.GetHashCode();
-            if (AttackServerInterval != 0F) hash ^= AttackServerInterval.GetHashCode();
-            if (RoundDurationSeconds != 0F) hash ^= RoundDurationSeconds.GetHashCode();
-            if (BonusTimePerAllySeconds != 0F) hash ^= BonusTimePerAllySeconds.GetHashCode();
-            if (MaximumAttackersPerBattle != 0) hash ^= MaximumAttackersPerBattle.GetHashCode();
-            if (SameTypeAttackBonusMultiplier != 0F) hash ^= SameTypeAttackBonusMultiplier.GetHashCode();
-            if (MaximumEnergy != 0) hash ^= MaximumEnergy.GetHashCode();
-            if (EnergyDeltaPerHealthLost != 0F) hash ^= EnergyDeltaPerHealthLost.GetHashCode();
-            if (DodgeDurationMs != 0) hash ^= DodgeDurationMs.GetHashCode();
-            if (MinimumPlayerLevel != 0) hash ^= MinimumPlayerLevel.GetHashCode();
-            if (SwapDurationMs != 0) hash ^= SwapDurationMs.GetHashCode();
-            return hash;
-        }
-
-        partial void OnConstruction();
-
-        public override string ToString()
-        {
-            return pb::JsonFormatter.ToDiagnosticString(this);
-        }
-    }
-
-    [global::System.Diagnostics.DebuggerNonUserCodeAttribute()]
-    public sealed partial class GymLevelSettings : pb::IMessage<GymLevelSettings>
-    {
-        /// <summary>Field number for the "required_experience" field.</summary>
-        public const int RequiredExperienceFieldNumber = 1;
-
-        /// <summary>Field number for the "leader_slots" field.</summary>
-        public const int LeaderSlotsFieldNumber = 2;
-
-        /// <summary>Field number for the "trainer_slots" field.</summary>
-        public const int TrainerSlotsFieldNumber = 3;
-
-        /// <summary>Field number for the "search_roll_bonus" field.</summary>
-        public const int SearchRollBonusFieldNumber = 4;
-
-        private static readonly pb::MessageParser<GymLevelSettings> _parser =
-            new pb::MessageParser<GymLevelSettings>(() => new GymLevelSettings());
-
-        private static readonly pb::FieldCodec<int> _repeated_requiredExperience_codec
-            = pb::FieldCodec.ForInt32(10);
-
-        private static readonly pb::FieldCodec<int> _repeated_leaderSlots_codec
-            = pb::FieldCodec.ForInt32(18);
-
-        private static readonly pb::FieldCodec<int> _repeated_trainerSlots_codec
-            = pb::FieldCodec.ForInt32(26);
-
-        private static readonly pb::FieldCodec<int> _repeated_searchRollBonus_codec
-            = pb::FieldCodec.ForInt32(34);
-
-        private readonly pbc::RepeatedField<int> leaderSlots_ = new pbc::RepeatedField<int>();
-        private readonly pbc::RepeatedField<int> requiredExperience_ = new pbc::RepeatedField<int>();
-        private readonly pbc::RepeatedField<int> searchRollBonus_ = new pbc::RepeatedField<int>();
-        private readonly pbc::RepeatedField<int> trainerSlots_ = new pbc::RepeatedField<int>();
-
-        public GymLevelSettings()
-        {
-            OnConstruction();
-        }
-
-        public GymLevelSettings(GymLevelSettings other) : this()
-        {
-            requiredExperience_ = other.requiredExperience_.Clone();
-            leaderSlots_ = other.leaderSlots_.Clone();
-            trainerSlots_ = other.trainerSlots_.Clone();
-            searchRollBonus_ = other.searchRollBonus_.Clone();
-        }
-
-        public static pb::MessageParser<GymLevelSettings> Parser
-        {
-            get { return _parser; }
-        }
-
-        public static pbr::MessageDescriptor Descriptor
-        {
-            get { return global::PokemonGo.RocketAPI.GeneratedCode.PayloadsReflection.Descriptor.MessageTypes[72]; }
-        }
-
-        public pbc::RepeatedField<int> RequiredExperience
-        {
-            get { return requiredExperience_; }
-        }
-
-        public pbc::RepeatedField<int> LeaderSlots
-        {
-            get { return leaderSlots_; }
-        }
-
-        public pbc::RepeatedField<int> TrainerSlots
-        {
-            get { return trainerSlots_; }
-        }
-
-        public pbc::RepeatedField<int> SearchRollBonus
-        {
-            get { return searchRollBonus_; }
-        }
-
-        pbr::MessageDescriptor pb::IMessage.Descriptor
-        {
-            get { return Descriptor; }
-        }
-
-        public GymLevelSettings Clone()
-        {
-            return new GymLevelSettings(this);
-        }
-
-        public bool Equals(GymLevelSettings other)
-        {
-            if (ReferenceEquals(other, null))
-            {
-                return false;
-            }
-            if (ReferenceEquals(other, this))
-            {
-                return true;
-            }
-            if (!requiredExperience_.Equals(other.requiredExperience_)) return false;
-            if (!leaderSlots_.Equals(other.leaderSlots_)) return false;
-            if (!trainerSlots_.Equals(other.trainerSlots_)) return false;
-            if (!searchRollBonus_.Equals(other.searchRollBonus_)) return false;
-            return true;
-        }
-
-        public void WriteTo(pb::CodedOutputStream output)
-        {
-            requiredExperience_.WriteTo(output, _repeated_requiredExperience_codec);
-            leaderSlots_.WriteTo(output, _repeated_leaderSlots_codec);
-            trainerSlots_.WriteTo(output, _repeated_trainerSlots_codec);
-            searchRollBonus_.WriteTo(output, _repeated_searchRollBonus_codec);
-        }
-
-        public int CalculateSize()
-        {
-            var size = 0;
-            size += requiredExperience_.CalculateSize(_repeated_requiredExperience_codec);
-            size += leaderSlots_.CalculateSize(_repeated_leaderSlots_codec);
-            size += trainerSlots_.CalculateSize(_repeated_trainerSlots_codec);
-            size += searchRollBonus_.CalculateSize(_repeated_searchRollBonus_codec);
-            return size;
-        }
-
-        public void MergeFrom(GymLevelSettings other)
-        {
-            if (other == null)
-            {
-                return;
-            }
-            requiredExperience_.Add(other.requiredExperience_);
-            leaderSlots_.Add(other.leaderSlots_);
-            trainerSlots_.Add(other.trainerSlots_);
-            searchRollBonus_.Add(other.searchRollBonus_);
-        }
-
-        public void MergeFrom(pb::CodedInputStream input)
-        {
-            uint tag;
-            while ((tag = input.ReadTag()) != 0)
-            {
-                switch (tag)
-                {
-                    default:
-                        input.SkipLastField();
-                        break;
-                    case 10:
-                    case 8:
-                        {
-                            requiredExperience_.AddEntriesFrom(input, _repeated_requiredExperience_codec);
-                            break;
-                        }
-                    case 18:
-                    case 16:
-                        {
-                            leaderSlots_.AddEntriesFrom(input, _repeated_leaderSlots_codec);
-                            break;
-                        }
-                    case 26:
-                    case 24:
-                        {
-                            trainerSlots_.AddEntriesFrom(input, _repeated_trainerSlots_codec);
-                            break;
-                        }
-                    case 34:
-                    case 32:
-                        {
-                            searchRollBonus_.AddEntriesFrom(input, _repeated_searchRollBonus_codec);
-                            break;
-                        }
-                }
-            }
-        }
-
-        public override bool Equals(object other)
-        {
-            return Equals(other as GymLevelSettings);
-        }
-
-        public override int GetHashCode()
-        {
-            var hash = 1;
-            hash ^= requiredExperience_.GetHashCode();
-            hash ^= leaderSlots_.GetHashCode();
-            hash ^= trainerSlots_.GetHashCode();
-            hash ^= searchRollBonus_.GetHashCode();
-            return hash;
-        }
-
-        partial void OnConstruction();
-
-        public override string ToString()
-        {
-            return pb::JsonFormatter.ToDiagnosticString(this);
-        }
-    }
-
-    [global::System.Diagnostics.DebuggerNonUserCodeAttribute()]
-    public sealed partial class PlayerLevelSettings : pb::IMessage<PlayerLevelSettings>
-    {
-        /// <summary>Field number for the "rank_num" field.</summary>
-        public const int RankNumFieldNumber = 1;
-
-        /// <summary>Field number for the "required_experience" field.</summary>
-        public const int RequiredExperienceFieldNumber = 2;
-
-        /// <summary>Field number for the "cp_multiplier" field.</summary>
-        public const int CpMultiplierFieldNumber = 3;
-
-        /// <summary>Field number for the "max_egg_player_level" field.</summary>
-        public const int MaxEggPlayerLevelFieldNumber = 4;
-
-        /// <summary>Field number for the "max_encounter_player_level" field.</summary>
-        public const int MaxEncounterPlayerLevelFieldNumber = 5;
-
-        private static readonly pb::MessageParser<PlayerLevelSettings> _parser =
-            new pb::MessageParser<PlayerLevelSettings>(() => new PlayerLevelSettings());
-
-        private static readonly pb::FieldCodec<int> _repeated_rankNum_codec
-            = pb::FieldCodec.ForInt32(10);
-
-        private static readonly pb::FieldCodec<int> _repeated_requiredExperience_codec
-            = pb::FieldCodec.ForInt32(18);
-
-        private static readonly pb::FieldCodec<float> _repeated_cpMultiplier_codec
-            = pb::FieldCodec.ForFloat(26);
-
-        private readonly pbc::RepeatedField<float> cpMultiplier_ = new pbc::RepeatedField<float>();
-        private readonly pbc::RepeatedField<int> rankNum_ = new pbc::RepeatedField<int>();
-        private readonly pbc::RepeatedField<int> requiredExperience_ = new pbc::RepeatedField<int>();
-        private int maxEggPlayerLevel_;
-        private int maxEncounterPlayerLevel_;
-
-        public PlayerLevelSettings()
-        {
-            OnConstruction();
-        }
-
-        public PlayerLevelSettings(PlayerLevelSettings other) : this()
-        {
-            rankNum_ = other.rankNum_.Clone();
-            requiredExperience_ = other.requiredExperience_.Clone();
-            cpMultiplier_ = other.cpMultiplier_.Clone();
-            maxEggPlayerLevel_ = other.maxEggPlayerLevel_;
-            maxEncounterPlayerLevel_ = other.maxEncounterPlayerLevel_;
-        }
-
-        public static pb::MessageParser<PlayerLevelSettings> Parser
-        {
-            get { return _parser; }
-        }
-
-        public static pbr::MessageDescriptor Descriptor
-        {
-            get { return global::PokemonGo.RocketAPI.GeneratedCode.PayloadsReflection.Descriptor.MessageTypes[73]; }
-        }
-
-        public pbc::RepeatedField<int> RankNum
-        {
-            get { return rankNum_; }
-        }
-
-        public pbc::RepeatedField<int> RequiredExperience
-        {
-            get { return requiredExperience_; }
-        }
-
-        public pbc::RepeatedField<float> CpMultiplier
-        {
-            get { return cpMultiplier_; }
-        }
-
-        public int MaxEggPlayerLevel
-        {
-            get { return maxEggPlayerLevel_; }
-            set { maxEggPlayerLevel_ = value; }
-        }
-
-        public int MaxEncounterPlayerLevel
-        {
-            get { return maxEncounterPlayerLevel_; }
-            set { maxEncounterPlayerLevel_ = value; }
-        }
-
-        pbr::MessageDescriptor pb::IMessage.Descriptor
-        {
-            get { return Descriptor; }
-        }
-
-        public PlayerLevelSettings Clone()
-        {
-            return new PlayerLevelSettings(this);
-        }
-
-        public bool Equals(PlayerLevelSettings other)
-        {
-            if (ReferenceEquals(other, null))
-            {
-                return false;
-            }
-            if (ReferenceEquals(other, this))
-            {
-                return true;
-            }
-            if (!rankNum_.Equals(other.rankNum_)) return false;
-            if (!requiredExperience_.Equals(other.requiredExperience_)) return false;
-            if (!cpMultiplier_.Equals(other.cpMultiplier_)) return false;
-            if (MaxEggPlayerLevel != other.MaxEggPlayerLevel) return false;
-            if (MaxEncounterPlayerLevel != other.MaxEncounterPlayerLevel) return false;
-            return true;
-        }
-
-        public void WriteTo(pb::CodedOutputStream output)
-        {
-            rankNum_.WriteTo(output, _repeated_rankNum_codec);
-            requiredExperience_.WriteTo(output, _repeated_requiredExperience_codec);
-            cpMultiplier_.WriteTo(output, _repeated_cpMultiplier_codec);
-            if (MaxEggPlayerLevel != 0)
-            {
-                output.WriteRawTag(32);
-                output.WriteInt32(MaxEggPlayerLevel);
-            }
-            if (MaxEncounterPlayerLevel != 0)
-            {
-                output.WriteRawTag(40);
-                output.WriteInt32(MaxEncounterPlayerLevel);
-            }
-        }
-
-        public int CalculateSize()
-        {
-            var size = 0;
-            size += rankNum_.CalculateSize(_repeated_rankNum_codec);
-            size += requiredExperience_.CalculateSize(_repeated_requiredExperience_codec);
-            size += cpMultiplier_.CalculateSize(_repeated_cpMultiplier_codec);
-            if (MaxEggPlayerLevel != 0)
-            {
-                size += 1 + pb::CodedOutputStream.ComputeInt32Size(MaxEggPlayerLevel);
-            }
-            if (MaxEncounterPlayerLevel != 0)
-            {
-                size += 1 + pb::CodedOutputStream.ComputeInt32Size(MaxEncounterPlayerLevel);
-            }
-            return size;
-        }
-
-        public void MergeFrom(PlayerLevelSettings other)
-        {
-            if (other == null)
-            {
-                return;
-            }
-            rankNum_.Add(other.rankNum_);
-            requiredExperience_.Add(other.requiredExperience_);
-            cpMultiplier_.Add(other.cpMultiplier_);
-            if (other.MaxEggPlayerLevel != 0)
-            {
-                MaxEggPlayerLevel = other.MaxEggPlayerLevel;
-            }
-            if (other.MaxEncounterPlayerLevel != 0)
-            {
-                MaxEncounterPlayerLevel = other.MaxEncounterPlayerLevel;
-            }
-        }
-
-        public void MergeFrom(pb::CodedInputStream input)
-        {
-            uint tag;
-            while ((tag = input.ReadTag()) != 0)
-            {
-                switch (tag)
-                {
-                    default:
-                        input.SkipLastField();
-                        break;
-                    case 10:
-                    case 8:
-                        {
-                            rankNum_.AddEntriesFrom(input, _repeated_rankNum_codec);
-                            break;
-                        }
-                    case 18:
-                    case 16:
-                        {
-                            requiredExperience_.AddEntriesFrom(input, _repeated_requiredExperience_codec);
-                            break;
-                        }
-                    case 26:
-                    case 29:
-                        {
-                            cpMultiplier_.AddEntriesFrom(input, _repeated_cpMultiplier_codec);
-                            break;
-                        }
-                    case 32:
-                        {
-                            MaxEggPlayerLevel = input.ReadInt32();
-                            break;
-                        }
-                    case 40:
-                        {
-                            MaxEncounterPlayerLevel = input.ReadInt32();
-                            break;
-                        }
-                }
-            }
-        }
-
-        public override bool Equals(object other)
-        {
-            return Equals(other as PlayerLevelSettings);
-        }
-
-        public override int GetHashCode()
-        {
-            var hash = 1;
-            hash ^= rankNum_.GetHashCode();
-            hash ^= requiredExperience_.GetHashCode();
-            hash ^= cpMultiplier_.GetHashCode();
-            if (MaxEggPlayerLevel != 0) hash ^= MaxEggPlayerLevel.GetHashCode();
-            if (MaxEncounterPlayerLevel != 0) hash ^= MaxEncounterPlayerLevel.GetHashCode();
-            return hash;
-        }
-
-        partial void OnConstruction();
-
-        public override string ToString()
-        {
-            return pb::JsonFormatter.ToDiagnosticString(this);
-        }
-    }
-
-    [global::System.Diagnostics.DebuggerNonUserCodeAttribute()]
-    public sealed partial class CameraSettings : pb::IMessage<CameraSettings>
-    {
-        /// <summary>Field number for the "next_camera" field.</summary>
-        public const int NextCameraFieldNumber = 1;
-
-        /// <summary>Field number for the "interpolation" field.</summary>
-        public const int InterpolationFieldNumber = 2;
-
-        /// <summary>Field number for the "target_type" field.</summary>
-        public const int TargetTypeFieldNumber = 3;
-
-        /// <summary>Field number for the "ease_in_speed" field.</summary>
-        public const int EaseInSpeedFieldNumber = 4;
-
-        /// <summary>Field number for the "east_out_speed" field.</summary>
-        public const int EastOutSpeedFieldNumber = 5;
-
-        /// <summary>Field number for the "duration_seconds" field.</summary>
-        public const int DurationSecondsFieldNumber = 6;
-
-        /// <summary>Field number for the "wait_seconds" field.</summary>
-        public const int WaitSecondsFieldNumber = 7;
-
-        /// <summary>Field number for the "transition_seconds" field.</summary>
-        public const int TransitionSecondsFieldNumber = 8;
-
-        /// <summary>Field number for the "angle_degree" field.</summary>
-        public const int AngleDegreeFieldNumber = 9;
-
-        /// <summary>Field number for the "angle_offset_degree" field.</summary>
-        public const int AngleOffsetDegreeFieldNumber = 10;
-
-        /// <summary>Field number for the "pitch_degree" field.</summary>
-        public const int PitchDegreeFieldNumber = 11;
-
-        /// <summary>Field number for the "pitch_offset_degree" field.</summary>
-        public const int PitchOffsetDegreeFieldNumber = 12;
-
-        /// <summary>Field number for the "roll_degree" field.</summary>
-        public const int RollDegreeFieldNumber = 13;
-
-        /// <summary>Field number for the "distance_meters" field.</summary>
-        public const int DistanceMetersFieldNumber = 14;
-
-        /// <summary>Field number for the "height_percent" field.</summary>
-        public const int HeightPercentFieldNumber = 15;
-
-        /// <summary>Field number for the "vert_ctr_ratio" field.</summary>
-        public const int VertCtrRatioFieldNumber = 16;
-
-        private static readonly pb::MessageParser<CameraSettings> _parser =
-            new pb::MessageParser<CameraSettings>(() => new CameraSettings());
-
-        private static readonly pb::FieldCodec<global::PokemonGo.RocketAPI.GeneratedCode.CameraInterpolation>
-            _repeated_interpolation_codec
-                = pb::FieldCodec.ForEnum(18, x => (int)x,
-                    x => (global::PokemonGo.RocketAPI.GeneratedCode.CameraInterpolation)x);
-
-        private static readonly pb::FieldCodec<global::PokemonGo.RocketAPI.GeneratedCode.CameraTarget>
-            _repeated_targetType_codec
-                = pb::FieldCodec.ForEnum(26, x => (int)x,
-                    x => (global::PokemonGo.RocketAPI.GeneratedCode.CameraTarget)x);
-
-        private static readonly pb::FieldCodec<float> _repeated_easeInSpeed_codec
-            = pb::FieldCodec.ForFloat(34);
-
-        private static readonly pb::FieldCodec<float> _repeated_eastOutSpeed_codec
-            = pb::FieldCodec.ForFloat(42);
-
-        private static readonly pb::FieldCodec<float> _repeated_durationSeconds_codec
-            = pb::FieldCodec.ForFloat(50);
-
-        private static readonly pb::FieldCodec<float> _repeated_waitSeconds_codec
-            = pb::FieldCodec.ForFloat(58);
-
-        private static readonly pb::FieldCodec<float> _repeated_transitionSeconds_codec
-            = pb::FieldCodec.ForFloat(66);
-
-        private static readonly pb::FieldCodec<float> _repeated_angleDegree_codec
-            = pb::FieldCodec.ForFloat(74);
-
-        private static readonly pb::FieldCodec<float> _repeated_angleOffsetDegree_codec
-            = pb::FieldCodec.ForFloat(82);
-
-        private static readonly pb::FieldCodec<float> _repeated_pitchDegree_codec
-            = pb::FieldCodec.ForFloat(90);
-
-        private static readonly pb::FieldCodec<float> _repeated_pitchOffsetDegree_codec
-            = pb::FieldCodec.ForFloat(98);
-
-        private static readonly pb::FieldCodec<float> _repeated_rollDegree_codec
-            = pb::FieldCodec.ForFloat(106);
-
-        private static readonly pb::FieldCodec<float> _repeated_distanceMeters_codec
-            = pb::FieldCodec.ForFloat(114);
-
-        private static readonly pb::FieldCodec<float> _repeated_heightPercent_codec
-            = pb::FieldCodec.ForFloat(122);
-
-        private static readonly pb::FieldCodec<float> _repeated_vertCtrRatio_codec
-            = pb::FieldCodec.ForFloat(130);
-
-        private readonly pbc::RepeatedField<float> angleDegree_ = new pbc::RepeatedField<float>();
-        private readonly pbc::RepeatedField<float> angleOffsetDegree_ = new pbc::RepeatedField<float>();
-        private readonly pbc::RepeatedField<float> distanceMeters_ = new pbc::RepeatedField<float>();
-        private readonly pbc::RepeatedField<float> durationSeconds_ = new pbc::RepeatedField<float>();
-        private readonly pbc::RepeatedField<float> easeInSpeed_ = new pbc::RepeatedField<float>();
-        private readonly pbc::RepeatedField<float> eastOutSpeed_ = new pbc::RepeatedField<float>();
-        private readonly pbc::RepeatedField<float> heightPercent_ = new pbc::RepeatedField<float>();
-
-        private readonly pbc::RepeatedField<global::PokemonGo.RocketAPI.GeneratedCode.CameraInterpolation>
-            interpolation_ = new pbc::RepeatedField<global::PokemonGo.RocketAPI.GeneratedCode.CameraInterpolation>();
-
-        private readonly pbc::RepeatedField<float> pitchDegree_ = new pbc::RepeatedField<float>();
-        private readonly pbc::RepeatedField<float> pitchOffsetDegree_ = new pbc::RepeatedField<float>();
-        private readonly pbc::RepeatedField<float> rollDegree_ = new pbc::RepeatedField<float>();
-
-        private readonly pbc::RepeatedField<global::PokemonGo.RocketAPI.GeneratedCode.CameraTarget> targetType_ =
-            new pbc::RepeatedField<global::PokemonGo.RocketAPI.GeneratedCode.CameraTarget>();
-
-        private readonly pbc::RepeatedField<float> transitionSeconds_ = new pbc::RepeatedField<float>();
-        private readonly pbc::RepeatedField<float> vertCtrRatio_ = new pbc::RepeatedField<float>();
-        private readonly pbc::RepeatedField<float> waitSeconds_ = new pbc::RepeatedField<float>();
-        private string nextCamera_ = "";
-
-        public CameraSettings()
-        {
-            OnConstruction();
-        }
-
-        public CameraSettings(CameraSettings other) : this()
-        {
-            nextCamera_ = other.nextCamera_;
-            interpolation_ = other.interpolation_.Clone();
-            targetType_ = other.targetType_.Clone();
-            easeInSpeed_ = other.easeInSpeed_.Clone();
-            eastOutSpeed_ = other.eastOutSpeed_.Clone();
-            durationSeconds_ = other.durationSeconds_.Clone();
-            waitSeconds_ = other.waitSeconds_.Clone();
-            transitionSeconds_ = other.transitionSeconds_.Clone();
-            angleDegree_ = other.angleDegree_.Clone();
-            angleOffsetDegree_ = other.angleOffsetDegree_.Clone();
-            pitchDegree_ = other.pitchDegree_.Clone();
-            pitchOffsetDegree_ = other.pitchOffsetDegree_.Clone();
-            rollDegree_ = other.rollDegree_.Clone();
-            distanceMeters_ = other.distanceMeters_.Clone();
-            heightPercent_ = other.heightPercent_.Clone();
-            vertCtrRatio_ = other.vertCtrRatio_.Clone();
-        }
-
-        public static pb::MessageParser<CameraSettings> Parser
-        {
-            get { return _parser; }
-        }
-
-        public static pbr::MessageDescriptor Descriptor
-        {
-            get { return global::PokemonGo.RocketAPI.GeneratedCode.PayloadsReflection.Descriptor.MessageTypes[74]; }
-        }
-
-        public string NextCamera
-        {
-            get { return nextCamera_; }
-            set { nextCamera_ = pb::ProtoPreconditions.CheckNotNull(value, "value"); }
-        }
-
-        public pbc::RepeatedField<global::PokemonGo.RocketAPI.GeneratedCode.CameraInterpolation> Interpolation
-        {
-            get { return interpolation_; }
-        }
-
-        public pbc::RepeatedField<global::PokemonGo.RocketAPI.GeneratedCode.CameraTarget> TargetType
-        {
-            get { return targetType_; }
-        }
-
-        public pbc::RepeatedField<float> EaseInSpeed
-        {
-            get { return easeInSpeed_; }
-        }
-
-        public pbc::RepeatedField<float> EastOutSpeed
-        {
-            get { return eastOutSpeed_; }
-        }
-
-        public pbc::RepeatedField<float> DurationSeconds
-        {
-            get { return durationSeconds_; }
-        }
-
-        public pbc::RepeatedField<float> WaitSeconds
-        {
-            get { return waitSeconds_; }
-        }
-
-        public pbc::RepeatedField<float> TransitionSeconds
-        {
-            get { return transitionSeconds_; }
-        }
-
-        public pbc::RepeatedField<float> AngleDegree
-        {
-            get { return angleDegree_; }
-        }
-
-        public pbc::RepeatedField<float> AngleOffsetDegree
-        {
-            get { return angleOffsetDegree_; }
-        }
-
-        public pbc::RepeatedField<float> PitchDegree
-        {
-            get { return pitchDegree_; }
-        }
-
-        public pbc::RepeatedField<float> PitchOffsetDegree
-        {
-            get { return pitchOffsetDegree_; }
-        }
-
-        public pbc::RepeatedField<float> RollDegree
-        {
-            get { return rollDegree_; }
-        }
-
-        public pbc::RepeatedField<float> DistanceMeters
-        {
-            get { return distanceMeters_; }
-        }
-
-        public pbc::RepeatedField<float> HeightPercent
-        {
-            get { return heightPercent_; }
-        }
-
-        public pbc::RepeatedField<float> VertCtrRatio
-        {
-            get { return vertCtrRatio_; }
-        }
-
-        pbr::MessageDescriptor pb::IMessage.Descriptor
-        {
-            get { return Descriptor; }
-        }
-
-        public CameraSettings Clone()
-        {
-            return new CameraSettings(this);
-        }
-
-        public bool Equals(CameraSettings other)
-        {
-            if (ReferenceEquals(other, null))
-            {
-                return false;
-            }
-            if (ReferenceEquals(other, this))
-            {
-                return true;
-            }
-            if (NextCamera != other.NextCamera) return false;
-            if (!interpolation_.Equals(other.interpolation_)) return false;
-            if (!targetType_.Equals(other.targetType_)) return false;
-            if (!easeInSpeed_.Equals(other.easeInSpeed_)) return false;
-            if (!eastOutSpeed_.Equals(other.eastOutSpeed_)) return false;
-            if (!durationSeconds_.Equals(other.durationSeconds_)) return false;
-            if (!waitSeconds_.Equals(other.waitSeconds_)) return false;
-            if (!transitionSeconds_.Equals(other.transitionSeconds_)) return false;
-            if (!angleDegree_.Equals(other.angleDegree_)) return false;
-            if (!angleOffsetDegree_.Equals(other.angleOffsetDegree_)) return false;
-            if (!pitchDegree_.Equals(other.pitchDegree_)) return false;
-            if (!pitchOffsetDegree_.Equals(other.pitchOffsetDegree_)) return false;
-            if (!rollDegree_.Equals(other.rollDegree_)) return false;
-            if (!distanceMeters_.Equals(other.distanceMeters_)) return false;
-            if (!heightPercent_.Equals(other.heightPercent_)) return false;
-            if (!vertCtrRatio_.Equals(other.vertCtrRatio_)) return false;
-            return true;
-        }
-
-        public void WriteTo(pb::CodedOutputStream output)
-        {
-            if (NextCamera.Length != 0)
-            {
-                output.WriteRawTag(10);
-                output.WriteString(NextCamera);
-            }
-            interpolation_.WriteTo(output, _repeated_interpolation_codec);
-            targetType_.WriteTo(output, _repeated_targetType_codec);
-            easeInSpeed_.WriteTo(output, _repeated_easeInSpeed_codec);
-            eastOutSpeed_.WriteTo(output, _repeated_eastOutSpeed_codec);
-            durationSeconds_.WriteTo(output, _repeated_durationSeconds_codec);
-            waitSeconds_.WriteTo(output, _repeated_waitSeconds_codec);
-            transitionSeconds_.WriteTo(output, _repeated_transitionSeconds_codec);
-            angleDegree_.WriteTo(output, _repeated_angleDegree_codec);
-            angleOffsetDegree_.WriteTo(output, _repeated_angleOffsetDegree_codec);
-            pitchDegree_.WriteTo(output, _repeated_pitchDegree_codec);
-            pitchOffsetDegree_.WriteTo(output, _repeated_pitchOffsetDegree_codec);
-            rollDegree_.WriteTo(output, _repeated_rollDegree_codec);
-            distanceMeters_.WriteTo(output, _repeated_distanceMeters_codec);
-            heightPercent_.WriteTo(output, _repeated_heightPercent_codec);
-            vertCtrRatio_.WriteTo(output, _repeated_vertCtrRatio_codec);
-        }
-
-        public int CalculateSize()
-        {
-            var size = 0;
-            if (NextCamera.Length != 0)
-            {
-                size += 1 + pb::CodedOutputStream.ComputeStringSize(NextCamera);
-            }
-            size += interpolation_.CalculateSize(_repeated_interpolation_codec);
-            size += targetType_.CalculateSize(_repeated_targetType_codec);
-            size += easeInSpeed_.CalculateSize(_repeated_easeInSpeed_codec);
-            size += eastOutSpeed_.CalculateSize(_repeated_eastOutSpeed_codec);
-            size += durationSeconds_.CalculateSize(_repeated_durationSeconds_codec);
-            size += waitSeconds_.CalculateSize(_repeated_waitSeconds_codec);
-            size += transitionSeconds_.CalculateSize(_repeated_transitionSeconds_codec);
-            size += angleDegree_.CalculateSize(_repeated_angleDegree_codec);
-            size += angleOffsetDegree_.CalculateSize(_repeated_angleOffsetDegree_codec);
-            size += pitchDegree_.CalculateSize(_repeated_pitchDegree_codec);
-            size += pitchOffsetDegree_.CalculateSize(_repeated_pitchOffsetDegree_codec);
-            size += rollDegree_.CalculateSize(_repeated_rollDegree_codec);
-            size += distanceMeters_.CalculateSize(_repeated_distanceMeters_codec);
-            size += heightPercent_.CalculateSize(_repeated_heightPercent_codec);
-            size += vertCtrRatio_.CalculateSize(_repeated_vertCtrRatio_codec);
-            return size;
-        }
-
-        public void MergeFrom(CameraSettings other)
-        {
-            if (other == null)
-            {
-                return;
-            }
-            if (other.NextCamera.Length != 0)
-            {
-                NextCamera = other.NextCamera;
-            }
-            interpolation_.Add(other.interpolation_);
-            targetType_.Add(other.targetType_);
-            easeInSpeed_.Add(other.easeInSpeed_);
-            eastOutSpeed_.Add(other.eastOutSpeed_);
-            durationSeconds_.Add(other.durationSeconds_);
-            waitSeconds_.Add(other.waitSeconds_);
-            transitionSeconds_.Add(other.transitionSeconds_);
-            angleDegree_.Add(other.angleDegree_);
-            angleOffsetDegree_.Add(other.angleOffsetDegree_);
-            pitchDegree_.Add(other.pitchDegree_);
-            pitchOffsetDegree_.Add(other.pitchOffsetDegree_);
-            rollDegree_.Add(other.rollDegree_);
-            distanceMeters_.Add(other.distanceMeters_);
-            heightPercent_.Add(other.heightPercent_);
-            vertCtrRatio_.Add(other.vertCtrRatio_);
-        }
-
-        public void MergeFrom(pb::CodedInputStream input)
-        {
-            uint tag;
-            while ((tag = input.ReadTag()) != 0)
-            {
-                switch (tag)
-                {
-                    default:
-                        input.SkipLastField();
-                        break;
-                    case 10:
-                        {
-                            NextCamera = input.ReadString();
-                            break;
-                        }
-                    case 18:
-                    case 16:
-                        {
-                            interpolation_.AddEntriesFrom(input, _repeated_interpolation_codec);
-                            break;
-                        }
-                    case 26:
-                    case 24:
-                        {
-                            targetType_.AddEntriesFrom(input, _repeated_targetType_codec);
-                            break;
-                        }
-                    case 34:
-                    case 37:
-                        {
-                            easeInSpeed_.AddEntriesFrom(input, _repeated_easeInSpeed_codec);
-                            break;
-                        }
-                    case 42:
-                    case 45:
-                        {
-                            eastOutSpeed_.AddEntriesFrom(input, _repeated_eastOutSpeed_codec);
-                            break;
-                        }
-                    case 50:
-                    case 53:
-                        {
-                            durationSeconds_.AddEntriesFrom(input, _repeated_durationSeconds_codec);
-                            break;
-                        }
-                    case 58:
-                    case 61:
-                        {
-                            waitSeconds_.AddEntriesFrom(input, _repeated_waitSeconds_codec);
-                            break;
-                        }
-                    case 66:
-                    case 69:
-                        {
-                            transitionSeconds_.AddEntriesFrom(input, _repeated_transitionSeconds_codec);
-                            break;
-                        }
-                    case 74:
-                    case 77:
-                        {
-                            angleDegree_.AddEntriesFrom(input, _repeated_angleDegree_codec);
-                            break;
-                        }
-                    case 82:
-                    case 85:
-                        {
-                            angleOffsetDegree_.AddEntriesFrom(input, _repeated_angleOffsetDegree_codec);
-                            break;
-                        }
-                    case 90:
-                    case 93:
-                        {
-                            pitchDegree_.AddEntriesFrom(input, _repeated_pitchDegree_codec);
-                            break;
-                        }
-                    case 98:
-                    case 101:
-                        {
-                            pitchOffsetDegree_.AddEntriesFrom(input, _repeated_pitchOffsetDegree_codec);
-                            break;
-                        }
-                    case 106:
-                    case 109:
-                        {
-                            rollDegree_.AddEntriesFrom(input, _repeated_rollDegree_codec);
-                            break;
-                        }
-                    case 114:
-                    case 117:
-                        {
-                            distanceMeters_.AddEntriesFrom(input, _repeated_distanceMeters_codec);
-                            break;
-                        }
-                    case 122:
-                    case 125:
-                        {
-                            heightPercent_.AddEntriesFrom(input, _repeated_heightPercent_codec);
-                            break;
-                        }
-                    case 130:
-                    case 133:
-                        {
-                            vertCtrRatio_.AddEntriesFrom(input, _repeated_vertCtrRatio_codec);
-                            break;
-                        }
-                }
-            }
-        }
-
-        public override bool Equals(object other)
-        {
-            return Equals(other as CameraSettings);
-        }
-
-        public override int GetHashCode()
-        {
-            var hash = 1;
-            if (NextCamera.Length != 0) hash ^= NextCamera.GetHashCode();
-            hash ^= interpolation_.GetHashCode();
-            hash ^= targetType_.GetHashCode();
-            hash ^= easeInSpeed_.GetHashCode();
-            hash ^= eastOutSpeed_.GetHashCode();
-            hash ^= durationSeconds_.GetHashCode();
-            hash ^= waitSeconds_.GetHashCode();
-            hash ^= transitionSeconds_.GetHashCode();
-            hash ^= angleDegree_.GetHashCode();
-            hash ^= angleOffsetDegree_.GetHashCode();
-            hash ^= pitchDegree_.GetHashCode();
-            hash ^= pitchOffsetDegree_.GetHashCode();
-            hash ^= rollDegree_.GetHashCode();
-            hash ^= distanceMeters_.GetHashCode();
-            hash ^= heightPercent_.GetHashCode();
-            hash ^= vertCtrRatio_.GetHashCode();
-            return hash;
-        }
-
-        partial void OnConstruction();
-
-        public override string ToString()
-        {
-            return pb::JsonFormatter.ToDiagnosticString(this);
-        }
-    }
-
-    [global::System.Diagnostics.DebuggerNonUserCodeAttribute()]
-    public sealed partial class BadgeSettings : pb::IMessage<BadgeSettings>
-    {
-        /// <summary>Field number for the "badge_type" field.</summary>
-        public const int BadgeTypeFieldNumber = 1;
-
-        /// <summary>Field number for the "badge_rank" field.</summary>
-        public const int BadgeRankFieldNumber = 2;
-
-        /// <summary>Field number for the "targets" field.</summary>
-        public const int TargetsFieldNumber = 3;
-
-        private static readonly pb::MessageParser<BadgeSettings> _parser =
-            new pb::MessageParser<BadgeSettings>(() => new BadgeSettings());
-
-        private static readonly pb::FieldCodec<int> _repeated_targets_codec
-            = pb::FieldCodec.ForInt32(26);
-
-        private readonly pbc::RepeatedField<int> targets_ = new pbc::RepeatedField<int>();
-        private int badgeRank_;
-        private global::PokemonGo.RocketAPI.GeneratedCode.BadgeType badgeType_ = 0;
-
-        public BadgeSettings()
-        {
-            OnConstruction();
-        }
-
-        public BadgeSettings(BadgeSettings other) : this()
-        {
-            badgeType_ = other.badgeType_;
-            badgeRank_ = other.badgeRank_;
-            targets_ = other.targets_.Clone();
-        }
-
-        public static pb::MessageParser<BadgeSettings> Parser
-        {
-            get { return _parser; }
-        }
-
-        public static pbr::MessageDescriptor Descriptor
-        {
-            get { return global::PokemonGo.RocketAPI.GeneratedCode.PayloadsReflection.Descriptor.MessageTypes[75]; }
-        }
-
-        public global::PokemonGo.RocketAPI.GeneratedCode.BadgeType BadgeType
-        {
-            get { return badgeType_; }
-            set { badgeType_ = value; }
-        }
-
-        public int BadgeRank
-        {
-            get { return badgeRank_; }
-            set { badgeRank_ = value; }
-        }
-
-        public pbc::RepeatedField<int> Targets
-        {
-            get { return targets_; }
-        }
-
-        pbr::MessageDescriptor pb::IMessage.Descriptor
-        {
-            get { return Descriptor; }
-        }
-
-        public BadgeSettings Clone()
-        {
-            return new BadgeSettings(this);
-        }
-
-        public bool Equals(BadgeSettings other)
-        {
-            if (ReferenceEquals(other, null))
-            {
-                return false;
-            }
-            if (ReferenceEquals(other, this))
-            {
-                return true;
-            }
-            if (BadgeType != other.BadgeType) return false;
-            if (BadgeRank != other.BadgeRank) return false;
-            if (!targets_.Equals(other.targets_)) return false;
-            return true;
-        }
-
-        public void WriteTo(pb::CodedOutputStream output)
-        {
-            if (BadgeType != 0)
-            {
-                output.WriteRawTag(8);
-                output.WriteEnum((int)BadgeType);
-            }
-            if (BadgeRank != 0)
-            {
-                output.WriteRawTag(16);
-                output.WriteInt32(BadgeRank);
-            }
-            targets_.WriteTo(output, _repeated_targets_codec);
-        }
-
-        public int CalculateSize()
-        {
-            var size = 0;
-            if (BadgeType != 0)
-            {
-                size += 1 + pb::CodedOutputStream.ComputeEnumSize((int)BadgeType);
-            }
-            if (BadgeRank != 0)
-            {
-                size += 1 + pb::CodedOutputStream.ComputeInt32Size(BadgeRank);
-            }
-            size += targets_.CalculateSize(_repeated_targets_codec);
-            return size;
-        }
-
-        public void MergeFrom(BadgeSettings other)
-        {
-            if (other == null)
-            {
-                return;
-            }
-            if (other.BadgeType != 0)
-            {
-                BadgeType = other.BadgeType;
-            }
-            if (other.BadgeRank != 0)
-            {
-                BadgeRank = other.BadgeRank;
-            }
-            targets_.Add(other.targets_);
-        }
-
-        public void MergeFrom(pb::CodedInputStream input)
-        {
-            uint tag;
-            while ((tag = input.ReadTag()) != 0)
-            {
-                switch (tag)
-                {
-                    default:
-                        input.SkipLastField();
-                        break;
-                    case 8:
-                        {
-                            badgeType_ = (global::PokemonGo.RocketAPI.GeneratedCode.BadgeType)input.ReadEnum();
-                            break;
-                        }
-                    case 16:
-                        {
-                            BadgeRank = input.ReadInt32();
-                            break;
-                        }
-                    case 26:
-                    case 24:
-                        {
-                            targets_.AddEntriesFrom(input, _repeated_targets_codec);
-                            break;
-                        }
-                }
-            }
-        }
-
-        public override bool Equals(object other)
-        {
-            return Equals(other as BadgeSettings);
-        }
-
-        public override int GetHashCode()
-        {
-            var hash = 1;
-            if (BadgeType != 0) hash ^= BadgeType.GetHashCode();
-            if (BadgeRank != 0) hash ^= BadgeRank.GetHashCode();
-            hash ^= targets_.GetHashCode();
-            return hash;
-        }
-
-        partial void OnConstruction();
-
-        public override string ToString()
-        {
-            return pb::JsonFormatter.ToDiagnosticString(this);
-        }
-    }
-
-    [global::System.Diagnostics.DebuggerNonUserCodeAttribute()]
-    public sealed partial class TypeEffectiveSettings : pb::IMessage<TypeEffectiveSettings>
-    {
-        /// <summary>Field number for the "attack_scalar" field.</summary>
-        public const int AttackScalarFieldNumber = 1;
-
-        /// <summary>Field number for the "attack_type" field.</summary>
-        public const int AttackTypeFieldNumber = 2;
-
-        private static readonly pb::MessageParser<TypeEffectiveSettings> _parser =
-            new pb::MessageParser<TypeEffectiveSettings>(() => new TypeEffectiveSettings());
-
-        private static readonly pb::FieldCodec<float> _repeated_attackScalar_codec
-            = pb::FieldCodec.ForFloat(10);
-
-        private readonly pbc::RepeatedField<float> attackScalar_ = new pbc::RepeatedField<float>();
-        private global::PokemonGo.RocketAPI.GeneratedCode.PokemonType attackType_ = 0;
-
-        public TypeEffectiveSettings()
-        {
-            OnConstruction();
-        }
-
-        public TypeEffectiveSettings(TypeEffectiveSettings other) : this()
-        {
-            attackScalar_ = other.attackScalar_.Clone();
-            attackType_ = other.attackType_;
-        }
-
-        public static pb::MessageParser<TypeEffectiveSettings> Parser
-        {
-            get { return _parser; }
-        }
-
-        public static pbr::MessageDescriptor Descriptor
-        {
-            get { return global::PokemonGo.RocketAPI.GeneratedCode.PayloadsReflection.Descriptor.MessageTypes[76]; }
-        }
-
-        public pbc::RepeatedField<float> AttackScalar
-        {
-            get { return attackScalar_; }
-        }
-
-        public global::PokemonGo.RocketAPI.GeneratedCode.PokemonType AttackType
-        {
-            get { return attackType_; }
-            set { attackType_ = value; }
-        }
-
-        pbr::MessageDescriptor pb::IMessage.Descriptor
-        {
-            get { return Descriptor; }
-        }
-
-        public TypeEffectiveSettings Clone()
-        {
-            return new TypeEffectiveSettings(this);
-        }
-
-        public bool Equals(TypeEffectiveSettings other)
-        {
-            if (ReferenceEquals(other, null))
-            {
-                return false;
-            }
-            if (ReferenceEquals(other, this))
-            {
-                return true;
-            }
-            if (!attackScalar_.Equals(other.attackScalar_)) return false;
-            if (AttackType != other.AttackType) return false;
-            return true;
-        }
-
-        public void WriteTo(pb::CodedOutputStream output)
-        {
-            attackScalar_.WriteTo(output, _repeated_attackScalar_codec);
-            if (AttackType != 0)
-            {
-                output.WriteRawTag(16);
-                output.WriteEnum((int)AttackType);
-            }
-        }
-
-        public int CalculateSize()
-        {
-            var size = 0;
-            size += attackScalar_.CalculateSize(_repeated_attackScalar_codec);
-            if (AttackType != 0)
-            {
-                size += 1 + pb::CodedOutputStream.ComputeEnumSize((int)AttackType);
-            }
-            return size;
-        }
-
-        public void MergeFrom(TypeEffectiveSettings other)
-        {
-            if (other == null)
-            {
-                return;
-            }
-            attackScalar_.Add(other.attackScalar_);
-            if (other.AttackType != 0)
-            {
-                AttackType = other.AttackType;
-            }
-        }
-
-        public void MergeFrom(pb::CodedInputStream input)
-        {
-            uint tag;
-            while ((tag = input.ReadTag()) != 0)
-            {
-                switch (tag)
-                {
-                    default:
-                        input.SkipLastField();
-                        break;
-                    case 10:
-                    case 13:
-                        {
-                            attackScalar_.AddEntriesFrom(input, _repeated_attackScalar_codec);
-                            break;
-                        }
-                    case 16:
-                        {
-                            attackType_ = (global::PokemonGo.RocketAPI.GeneratedCode.PokemonType)input.ReadEnum();
-                            break;
-                        }
-                }
-            }
-        }
-
-        public override bool Equals(object other)
-        {
-            return Equals(other as TypeEffectiveSettings);
-        }
-
-        public override int GetHashCode()
-        {
-            var hash = 1;
-            hash ^= attackScalar_.GetHashCode();
-            if (AttackType != 0) hash ^= AttackType.GetHashCode();
-            return hash;
-        }
-
-        partial void OnConstruction();
-
-        public override string ToString()
-        {
-            return pb::JsonFormatter.ToDiagnosticString(this);
-        }
-    }
-
-    [global::System.Diagnostics.DebuggerNonUserCodeAttribute()]
-    public sealed partial class MoveSequenceSettings : pb::IMessage<MoveSequenceSettings>
-    {
-        /// <summary>Field number for the "sequence" field.</summary>
-        public const int SequenceFieldNumber = 1;
-
-        private static readonly pb::MessageParser<MoveSequenceSettings> _parser =
-            new pb::MessageParser<MoveSequenceSettings>(() => new MoveSequenceSettings());
-
-        private static readonly pb::FieldCodec<string> _repeated_sequence_codec
-            = pb::FieldCodec.ForString(10);
-
-        private readonly pbc::RepeatedField<string> sequence_ = new pbc::RepeatedField<string>();
-
-        public MoveSequenceSettings()
-        {
-            OnConstruction();
-        }
-
-        public MoveSequenceSettings(MoveSequenceSettings other) : this()
-        {
-            sequence_ = other.sequence_.Clone();
-        }
-
-        public static pb::MessageParser<MoveSequenceSettings> Parser
-        {
-            get { return _parser; }
-        }
-
-        public static pbr::MessageDescriptor Descriptor
-        {
-            get { return global::PokemonGo.RocketAPI.GeneratedCode.PayloadsReflection.Descriptor.MessageTypes[77]; }
-        }
-
-        public pbc::RepeatedField<string> Sequence
-        {
-            get { return sequence_; }
-        }
-
-        pbr::MessageDescriptor pb::IMessage.Descriptor
-        {
-            get { return Descriptor; }
-        }
-
-        public MoveSequenceSettings Clone()
-        {
-            return new MoveSequenceSettings(this);
-        }
-
-        public bool Equals(MoveSequenceSettings other)
-        {
-            if (ReferenceEquals(other, null))
-            {
-                return false;
-            }
-            if (ReferenceEquals(other, this))
-            {
-                return true;
-            }
-            if (!sequence_.Equals(other.sequence_)) return false;
-            return true;
-        }
-
-        public void WriteTo(pb::CodedOutputStream output)
-        {
-            sequence_.WriteTo(output, _repeated_sequence_codec);
-        }
-
-        public int CalculateSize()
-        {
-            var size = 0;
-            size += sequence_.CalculateSize(_repeated_sequence_codec);
-            return size;
-        }
-
-        public void MergeFrom(MoveSequenceSettings other)
-        {
-            if (other == null)
-            {
-                return;
-            }
-            sequence_.Add(other.sequence_);
-        }
-
-        public void MergeFrom(pb::CodedInputStream input)
-        {
-            uint tag;
-            while ((tag = input.ReadTag()) != 0)
-            {
-                switch (tag)
-                {
-                    default:
-                        input.SkipLastField();
-                        break;
-                    case 10:
-                        {
-                            sequence_.AddEntriesFrom(input, _repeated_sequence_codec);
-                            break;
-                        }
-                }
-            }
-        }
-
-        public override bool Equals(object other)
-        {
-            return Equals(other as MoveSequenceSettings);
-        }
-
-        public override int GetHashCode()
-        {
-            var hash = 1;
-            hash ^= sequence_.GetHashCode();
-            return hash;
-        }
-
-        partial void OnConstruction();
-
-        public override string ToString()
-        {
-            return pb::JsonFormatter.ToDiagnosticString(this);
-        }
-    }
-
-    [global::System.Diagnostics.DebuggerNonUserCodeAttribute()]
-    public sealed partial class MoveSettings : pb::IMessage<MoveSettings>
-    {
-        /// <summary>Field number for the "movement_id" field.</summary>
-        public const int MovementIdFieldNumber = 1;
-
-        /// <summary>Field number for the "animation_id" field.</summary>
-        public const int AnimationIdFieldNumber = 2;
-
-        /// <summary>Field number for the "pokemon_type" field.</summary>
-        public const int PokemonTypeFieldNumber = 3;
-
-        /// <summary>Field number for the "power" field.</summary>
-        public const int PowerFieldNumber = 4;
-
-        /// <summary>Field number for the "accuracy_chance" field.</summary>
-        public const int AccuracyChanceFieldNumber = 5;
-
-        /// <summary>Field number for the "critical_chance" field.</summary>
-        public const int CriticalChanceFieldNumber = 6;
-
-        /// <summary>Field number for the "heal_scalar" field.</summary>
-        public const int HealScalarFieldNumber = 7;
-
-        /// <summary>Field number for the "stamina_loss_scalar" field.</summary>
-        public const int StaminaLossScalarFieldNumber = 8;
-
-        /// <summary>Field number for the "trainer_level_min" field.</summary>
-        public const int TrainerLevelMinFieldNumber = 9;
-
-        /// <summary>Field number for the "trainer_level_max" field.</summary>
-        public const int TrainerLevelMaxFieldNumber = 10;
-
-        /// <summary>Field number for the "vfx_name" field.</summary>
-        public const int VfxNameFieldNumber = 11;
-
-        /// <summary>Field number for the "duration_ms" field.</summary>
-        public const int DurationMsFieldNumber = 12;
-
-        /// <summary>Field number for the "damage_window_start_ms" field.</summary>
-        public const int DamageWindowStartMsFieldNumber = 13;
-
-        /// <summary>Field number for the "damage_window_end_ms" field.</summary>
-        public const int DamageWindowEndMsFieldNumber = 14;
-
-        /// <summary>Field number for the "energy_delta" field.</summary>
-        public const int EnergyDeltaFieldNumber = 15;
-
-        private static readonly pb::MessageParser<MoveSettings> _parser =
-            new pb::MessageParser<MoveSettings>(() => new MoveSettings());
-
-        private float accuracyChance_;
-        private int animationId_;
-        private float criticalChance_;
-        private int damageWindowEndMs_;
-        private int damageWindowStartMs_;
-        private int durationMs_;
-        private int energyDelta_;
-        private float healScalar_;
-        private global::PokemonGo.RocketAPI.GeneratedCode.PokemonMovementType movementId_ = 0;
-        private global::PokemonGo.RocketAPI.GeneratedCode.PokemonType pokemonType_ = 0;
-        private float power_;
-        private float staminaLossScalar_;
-        private int trainerLevelMax_;
-        private int trainerLevelMin_;
-        private string vfxName_ = "";
-
-        public MoveSettings()
-        {
-            OnConstruction();
-        }
-
-        public MoveSettings(MoveSettings other) : this()
-        {
-            movementId_ = other.movementId_;
-            animationId_ = other.animationId_;
-            pokemonType_ = other.pokemonType_;
-            power_ = other.power_;
-            accuracyChance_ = other.accuracyChance_;
-            criticalChance_ = other.criticalChance_;
-            healScalar_ = other.healScalar_;
-            staminaLossScalar_ = other.staminaLossScalar_;
-            trainerLevelMin_ = other.trainerLevelMin_;
-            trainerLevelMax_ = other.trainerLevelMax_;
-            vfxName_ = other.vfxName_;
-            durationMs_ = other.durationMs_;
-            damageWindowStartMs_ = other.damageWindowStartMs_;
-            damageWindowEndMs_ = other.damageWindowEndMs_;
-            energyDelta_ = other.energyDelta_;
-        }
-
-        public static pb::MessageParser<MoveSettings> Parser
-        {
-            get { return _parser; }
-        }
-
-        public static pbr::MessageDescriptor Descriptor
-        {
-            get { return global::PokemonGo.RocketAPI.GeneratedCode.PayloadsReflection.Descriptor.MessageTypes[78]; }
-        }
-
-        public global::PokemonGo.RocketAPI.GeneratedCode.PokemonMovementType MovementId
-        {
-            get { return movementId_; }
-            set { movementId_ = value; }
-        }
-
-        public int AnimationId
-        {
-            get { return animationId_; }
-            set { animationId_ = value; }
-        }
-
-        public global::PokemonGo.RocketAPI.GeneratedCode.PokemonType PokemonType
-        {
-            get { return pokemonType_; }
-            set { pokemonType_ = value; }
-        }
-
-        public float Power
-        {
-            get { return power_; }
-            set { power_ = value; }
-        }
-
-        public float AccuracyChance
-        {
-            get { return accuracyChance_; }
-            set { accuracyChance_ = value; }
-        }
-
-        public float CriticalChance
-        {
-            get { return criticalChance_; }
-            set { criticalChance_ = value; }
-        }
-
-        public float HealScalar
-        {
-            get { return healScalar_; }
-            set { healScalar_ = value; }
-        }
-
-        public float StaminaLossScalar
-        {
-            get { return staminaLossScalar_; }
-            set { staminaLossScalar_ = value; }
-        }
-
-        public int TrainerLevelMin
-        {
-            get { return trainerLevelMin_; }
-            set { trainerLevelMin_ = value; }
-        }
-
-        public int TrainerLevelMax
-        {
-            get { return trainerLevelMax_; }
-            set { trainerLevelMax_ = value; }
-        }
-
-        public string VfxName
-        {
-            get { return vfxName_; }
-            set { vfxName_ = pb::ProtoPreconditions.CheckNotNull(value, "value"); }
-        }
-
-        public int DurationMs
-        {
-            get { return durationMs_; }
-            set { durationMs_ = value; }
-        }
-
-        public int DamageWindowStartMs
-        {
-            get { return damageWindowStartMs_; }
-            set { damageWindowStartMs_ = value; }
-        }
-
-        public int DamageWindowEndMs
-        {
-            get { return damageWindowEndMs_; }
-            set { damageWindowEndMs_ = value; }
-        }
-
-        public int EnergyDelta
-        {
-            get { return energyDelta_; }
-            set { energyDelta_ = value; }
-        }
-
-        pbr::MessageDescriptor pb::IMessage.Descriptor
-        {
-            get { return Descriptor; }
-        }
-
-        public MoveSettings Clone()
-        {
-            return new MoveSettings(this);
-        }
-
-        public bool Equals(MoveSettings other)
-        {
-            if (ReferenceEquals(other, null))
-            {
-                return false;
-            }
-            if (ReferenceEquals(other, this))
-            {
-                return true;
-            }
-            if (MovementId != other.MovementId) return false;
-            if (AnimationId != other.AnimationId) return false;
-            if (PokemonType != other.PokemonType) return false;
-            if (Power != other.Power) return false;
-            if (AccuracyChance != other.AccuracyChance) return false;
-            if (CriticalChance != other.CriticalChance) return false;
-            if (HealScalar != other.HealScalar) return false;
-            if (StaminaLossScalar != other.StaminaLossScalar) return false;
-            if (TrainerLevelMin != other.TrainerLevelMin) return false;
-            if (TrainerLevelMax != other.TrainerLevelMax) return false;
-            if (VfxName != other.VfxName) return false;
-            if (DurationMs != other.DurationMs) return false;
-            if (DamageWindowStartMs != other.DamageWindowStartMs) return false;
-            if (DamageWindowEndMs != other.DamageWindowEndMs) return false;
-            if (EnergyDelta != other.EnergyDelta) return false;
-            return true;
-        }
-
-        public void WriteTo(pb::CodedOutputStream output)
-        {
-            if (MovementId != 0)
-            {
-                output.WriteRawTag(8);
-                output.WriteEnum((int)MovementId);
-            }
-            if (AnimationId != 0)
-            {
-                output.WriteRawTag(16);
-                output.WriteInt32(AnimationId);
-            }
-            if (PokemonType != 0)
-            {
-                output.WriteRawTag(24);
-                output.WriteEnum((int)PokemonType);
-            }
-            if (Power != 0F)
-            {
-                output.WriteRawTag(37);
-                output.WriteFloat(Power);
-            }
-            if (AccuracyChance != 0F)
-            {
-                output.WriteRawTag(45);
-                output.WriteFloat(AccuracyChance);
-            }
-            if (CriticalChance != 0F)
-            {
-                output.WriteRawTag(53);
-                output.WriteFloat(CriticalChance);
-            }
-            if (HealScalar != 0F)
-            {
-                output.WriteRawTag(61);
-                output.WriteFloat(HealScalar);
-            }
-            if (StaminaLossScalar != 0F)
-            {
-                output.WriteRawTag(69);
-                output.WriteFloat(StaminaLossScalar);
-            }
-            if (TrainerLevelMin != 0)
-            {
-                output.WriteRawTag(72);
-                output.WriteInt32(TrainerLevelMin);
-            }
-            if (TrainerLevelMax != 0)
-            {
-                output.WriteRawTag(80);
-                output.WriteInt32(TrainerLevelMax);
-            }
-            if (VfxName.Length != 0)
-            {
-                output.WriteRawTag(90);
-                output.WriteString(VfxName);
-            }
-            if (DurationMs != 0)
-            {
-                output.WriteRawTag(96);
-                output.WriteInt32(DurationMs);
-            }
-            if (DamageWindowStartMs != 0)
-            {
-                output.WriteRawTag(104);
-                output.WriteInt32(DamageWindowStartMs);
-            }
-            if (DamageWindowEndMs != 0)
-            {
-                output.WriteRawTag(112);
-                output.WriteInt32(DamageWindowEndMs);
-            }
-            if (EnergyDelta != 0)
-            {
-                output.WriteRawTag(120);
-                output.WriteInt32(EnergyDelta);
-            }
-        }
-
-        public int CalculateSize()
-        {
-            var size = 0;
-            if (MovementId != 0)
-            {
-                size += 1 + pb::CodedOutputStream.ComputeEnumSize((int)MovementId);
-            }
-            if (AnimationId != 0)
-            {
-                size += 1 + pb::CodedOutputStream.ComputeInt32Size(AnimationId);
-            }
-            if (PokemonType != 0)
-            {
-                size += 1 + pb::CodedOutputStream.ComputeEnumSize((int)PokemonType);
-            }
-            if (Power != 0F)
-            {
-                size += 1 + 4;
-            }
-            if (AccuracyChance != 0F)
-            {
-                size += 1 + 4;
-            }
-            if (CriticalChance != 0F)
-            {
-                size += 1 + 4;
-            }
-            if (HealScalar != 0F)
-            {
-                size += 1 + 4;
-            }
-            if (StaminaLossScalar != 0F)
-            {
-                size += 1 + 4;
-            }
-            if (TrainerLevelMin != 0)
-            {
-                size += 1 + pb::CodedOutputStream.ComputeInt32Size(TrainerLevelMin);
-            }
-            if (TrainerLevelMax != 0)
-            {
-                size += 1 + pb::CodedOutputStream.ComputeInt32Size(TrainerLevelMax);
-            }
-            if (VfxName.Length != 0)
-            {
-                size += 1 + pb::CodedOutputStream.ComputeStringSize(VfxName);
-            }
-            if (DurationMs != 0)
-            {
-                size += 1 + pb::CodedOutputStream.ComputeInt32Size(DurationMs);
-            }
-            if (DamageWindowStartMs != 0)
-            {
-                size += 1 + pb::CodedOutputStream.ComputeInt32Size(DamageWindowStartMs);
-            }
-            if (DamageWindowEndMs != 0)
-            {
-                size += 1 + pb::CodedOutputStream.ComputeInt32Size(DamageWindowEndMs);
-            }
-            if (EnergyDelta != 0)
-            {
-                size += 1 + pb::CodedOutputStream.ComputeInt32Size(EnergyDelta);
-            }
-            return size;
-        }
-
-        public void MergeFrom(MoveSettings other)
-        {
-            if (other == null)
-            {
-                return;
-            }
-            if (other.MovementId != 0)
-            {
-                MovementId = other.MovementId;
-            }
-            if (other.AnimationId != 0)
-            {
-                AnimationId = other.AnimationId;
-            }
-            if (other.PokemonType != 0)
-            {
-                PokemonType = other.PokemonType;
-            }
-            if (other.Power != 0F)
-            {
-                Power = other.Power;
-            }
-            if (other.AccuracyChance != 0F)
-            {
-                AccuracyChance = other.AccuracyChance;
-            }
-            if (other.CriticalChance != 0F)
-            {
-                CriticalChance = other.CriticalChance;
-            }
-            if (other.HealScalar != 0F)
-            {
-                HealScalar = other.HealScalar;
-            }
-            if (other.StaminaLossScalar != 0F)
-            {
-                StaminaLossScalar = other.StaminaLossScalar;
-            }
-            if (other.TrainerLevelMin != 0)
-            {
-                TrainerLevelMin = other.TrainerLevelMin;
-            }
-            if (other.TrainerLevelMax != 0)
-            {
-                TrainerLevelMax = other.TrainerLevelMax;
-            }
-            if (other.VfxName.Length != 0)
-            {
-                VfxName = other.VfxName;
-            }
-            if (other.DurationMs != 0)
-            {
-                DurationMs = other.DurationMs;
-            }
-            if (other.DamageWindowStartMs != 0)
-            {
-                DamageWindowStartMs = other.DamageWindowStartMs;
-            }
-            if (other.DamageWindowEndMs != 0)
-            {
-                DamageWindowEndMs = other.DamageWindowEndMs;
-            }
-            if (other.EnergyDelta != 0)
-            {
-                EnergyDelta = other.EnergyDelta;
-            }
-        }
-
-        public void MergeFrom(pb::CodedInputStream input)
-        {
-            uint tag;
-            while ((tag = input.ReadTag()) != 0)
-            {
-                switch (tag)
-                {
-                    default:
-                        input.SkipLastField();
-                        break;
-                    case 8:
-                        {
-                            movementId_ = (global::PokemonGo.RocketAPI.GeneratedCode.PokemonMovementType)input.ReadEnum();
-                            break;
-                        }
-                    case 16:
-                        {
-                            AnimationId = input.ReadInt32();
-                            break;
-                        }
-                    case 24:
-                        {
-                            pokemonType_ = (global::PokemonGo.RocketAPI.GeneratedCode.PokemonType)input.ReadEnum();
-                            break;
-                        }
-                    case 37:
-                        {
-                            Power = input.ReadFloat();
-                            break;
-                        }
-                    case 45:
-                        {
-                            AccuracyChance = input.ReadFloat();
-                            break;
-                        }
-                    case 53:
-                        {
-                            CriticalChance = input.ReadFloat();
-                            break;
-                        }
-                    case 61:
-                        {
-                            HealScalar = input.ReadFloat();
-                            break;
-                        }
-                    case 69:
-                        {
-                            StaminaLossScalar = input.ReadFloat();
-                            break;
-                        }
-                    case 72:
-                        {
-                            TrainerLevelMin = input.ReadInt32();
-                            break;
-                        }
-                    case 80:
-                        {
-                            TrainerLevelMax = input.ReadInt32();
-                            break;
-                        }
-                    case 90:
-                        {
-                            VfxName = input.ReadString();
-                            break;
-                        }
-                    case 96:
-                        {
-                            DurationMs = input.ReadInt32();
-                            break;
-                        }
-                    case 104:
-                        {
-                            DamageWindowStartMs = input.ReadInt32();
-                            break;
-                        }
-                    case 112:
-                        {
-                            DamageWindowEndMs = input.ReadInt32();
-                            break;
-                        }
-                    case 120:
-                        {
-                            EnergyDelta = input.ReadInt32();
-                            break;
-                        }
-                }
-            }
-        }
-
-        public override bool Equals(object other)
-        {
-            return Equals(other as MoveSettings);
-        }
-
-        public override int GetHashCode()
-        {
-            var hash = 1;
-            if (MovementId != 0) hash ^= MovementId.GetHashCode();
-            if (AnimationId != 0) hash ^= AnimationId.GetHashCode();
-            if (PokemonType != 0) hash ^= PokemonType.GetHashCode();
-            if (Power != 0F) hash ^= Power.GetHashCode();
-            if (AccuracyChance != 0F) hash ^= AccuracyChance.GetHashCode();
-            if (CriticalChance != 0F) hash ^= CriticalChance.GetHashCode();
-            if (HealScalar != 0F) hash ^= HealScalar.GetHashCode();
-            if (StaminaLossScalar != 0F) hash ^= StaminaLossScalar.GetHashCode();
-            if (TrainerLevelMin != 0) hash ^= TrainerLevelMin.GetHashCode();
-            if (TrainerLevelMax != 0) hash ^= TrainerLevelMax.GetHashCode();
-            if (VfxName.Length != 0) hash ^= VfxName.GetHashCode();
-            if (DurationMs != 0) hash ^= DurationMs.GetHashCode();
-            if (DamageWindowStartMs != 0) hash ^= DamageWindowStartMs.GetHashCode();
-            if (DamageWindowEndMs != 0) hash ^= DamageWindowEndMs.GetHashCode();
-            if (EnergyDelta != 0) hash ^= EnergyDelta.GetHashCode();
-            return hash;
-        }
-
-        partial void OnConstruction();
-
-        public override string ToString()
-        {
-            return pb::JsonFormatter.ToDiagnosticString(this);
-        }
-    }
-
-    [global::System.Diagnostics.DebuggerNonUserCodeAttribute()]
-    public sealed partial class PokemonSettings : pb::IMessage<PokemonSettings>
-    {
-        /// <summary>Field number for the "pokemon_id" field.</summary>
-        public const int PokemonIdFieldNumber = 1;
-
-        /// <summary>Field number for the "model_scale" field.</summary>
-        public const int ModelScaleFieldNumber = 3;
-
-        /// <summary>Field number for the "type" field.</summary>
-        public const int TypeFieldNumber = 4;
-
-        /// <summary>Field number for the "type_2" field.</summary>
-        public const int Type2FieldNumber = 5;
-
-        /// <summary>Field number for the "camera" field.</summary>
-        public const int CameraFieldNumber = 6;
-
-        /// <summary>Field number for the "encounter" field.</summary>
-        public const int EncounterFieldNumber = 7;
-
-        /// <summary>Field number for the "stats" field.</summary>
-        public const int StatsFieldNumber = 8;
-
-        /// <summary>Field number for the "quick_moves" field.</summary>
-        public const int QuickMovesFieldNumber = 9;
-
-        /// <summary>Field number for the "cinematic_moves" field.</summary>
-        public const int CinematicMovesFieldNumber = 10;
-
-        /// <summary>Field number for the "animation_time" field.</summary>
-        public const int AnimationTimeFieldNumber = 11;
-
-        /// <summary>Field number for the "evolution_ids" field.</summary>
-        public const int EvolutionIdsFieldNumber = 12;
-
-        /// <summary>Field number for the "evolution_pips" field.</summary>
-        public const int EvolutionPipsFieldNumber = 13;
-
-        /// <summary>Field number for the "class" field.</summary>
-        public const int ClassFieldNumber = 14;
-
-        /// <summary>Field number for the "pokedex_height_m" field.</summary>
-        public const int PokedexHeightMFieldNumber = 15;
-
-        /// <summary>Field number for the "pokedex_weight_kg" field.</summary>
-        public const int PokedexWeightKgFieldNumber = 16;
-
-        /// <summary>Field number for the "parent_pokemon_id" field.</summary>
-        public const int ParentPokemonIdFieldNumber = 17;
-
-        /// <summary>Field number for the "height_std_dev" field.</summary>
-        public const int HeightStdDevFieldNumber = 18;
-
-        /// <summary>Field number for the "weight_std_dev" field.</summary>
-        public const int WeightStdDevFieldNumber = 19;
-
-        /// <summary>Field number for the "km_distance_to_hatch" field.</summary>
-        public const int KmDistanceToHatchFieldNumber = 20;
-
-        /// <summary>Field number for the "family_id" field.</summary>
-        public const int FamilyIdFieldNumber = 21;
-
-        /// <summary>Field number for the "candy_to_evolve" field.</summary>
-        public const int CandyToEvolveFieldNumber = 22;
-
-        private static readonly pb::MessageParser<PokemonSettings> _parser =
-            new pb::MessageParser<PokemonSettings>(() => new PokemonSettings());
-
-        private static readonly pb::FieldCodec<global::PokemonGo.RocketAPI.GeneratedCode.PokemonMove>
-            _repeated_quickMoves_codec
-                = pb::FieldCodec.ForEnum(74, x => (int)x,
-                    x => (global::PokemonGo.RocketAPI.GeneratedCode.PokemonMove)x);
-
-        private static readonly pb::FieldCodec<global::PokemonGo.RocketAPI.GeneratedCode.PokemonMove>
-            _repeated_cinematicMoves_codec
-                = pb::FieldCodec.ForEnum(82, x => (int)x,
-                    x => (global::PokemonGo.RocketAPI.GeneratedCode.PokemonMove)x);
-
-        private static readonly pb::FieldCodec<float> _repeated_animationTime_codec
-            = pb::FieldCodec.ForFloat(90);
-
-        private static readonly pb::FieldCodec<global::PokemonGo.RocketAPI.GeneratedCode.PokemonId>
-            _repeated_evolutionIds_codec
-                = pb::FieldCodec.ForEnum(98, x => (int)x, x => (global::PokemonGo.RocketAPI.GeneratedCode.PokemonId)x);
-
-        private readonly pbc::RepeatedField<float> animationTime_ = new pbc::RepeatedField<float>();
-
-        private readonly pbc::RepeatedField<global::PokemonGo.RocketAPI.GeneratedCode.PokemonMove> cinematicMoves_ =
-            new pbc::RepeatedField<global::PokemonGo.RocketAPI.GeneratedCode.PokemonMove>();
-
-        private readonly pbc::RepeatedField<global::PokemonGo.RocketAPI.GeneratedCode.PokemonId> evolutionIds_ =
-            new pbc::RepeatedField<global::PokemonGo.RocketAPI.GeneratedCode.PokemonId>();
-
-        private readonly pbc::RepeatedField<global::PokemonGo.RocketAPI.GeneratedCode.PokemonMove> quickMoves_ =
-            new pbc::RepeatedField<global::PokemonGo.RocketAPI.GeneratedCode.PokemonMove>();
-
-        private global::PokemonGo.RocketAPI.GeneratedCode.CameraAttributes camera_;
-        private int candyToEvolve_;
-        private global::PokemonGo.RocketAPI.GeneratedCode.PokemonClass class_ = 0;
-        private global::PokemonGo.RocketAPI.GeneratedCode.EncounterAttributes encounter_;
-        private int evolutionPips_;
-        private global::PokemonGo.RocketAPI.GeneratedCode.PokemonFamilyId familyId_ = 0;
-        private float heightStdDev_;
-        private float kmDistanceToHatch_;
-        private float modelScale_;
-        private global::PokemonGo.RocketAPI.GeneratedCode.PokemonId parentPokemonId_ = 0;
-        private float pokedexHeightM_;
-        private float pokedexWeightKg_;
-        private global::PokemonGo.RocketAPI.GeneratedCode.PokemonId pokemonId_ = 0;
-        private global::PokemonGo.RocketAPI.GeneratedCode.StatsAttributes stats_;
-        private global::PokemonGo.RocketAPI.GeneratedCode.PokemonType type_ = 0;
-        private global::PokemonGo.RocketAPI.GeneratedCode.PokemonType type2_ = 0;
-        private float weightStdDev_;
-
-        public PokemonSettings()
-        {
-            OnConstruction();
-        }
-
-        public PokemonSettings(PokemonSettings other) : this()
-        {
-            pokemonId_ = other.pokemonId_;
-            modelScale_ = other.modelScale_;
-            type_ = other.type_;
-            type2_ = other.type2_;
-            Camera = other.camera_ != null ? other.Camera.Clone() : null;
-            Encounter = other.encounter_ != null ? other.Encounter.Clone() : null;
-            Stats = other.stats_ != null ? other.Stats.Clone() : null;
-            quickMoves_ = other.quickMoves_.Clone();
-            cinematicMoves_ = other.cinematicMoves_.Clone();
-            animationTime_ = other.animationTime_.Clone();
-            evolutionIds_ = other.evolutionIds_.Clone();
-            evolutionPips_ = other.evolutionPips_;
-            class_ = other.class_;
-            pokedexHeightM_ = other.pokedexHeightM_;
-            pokedexWeightKg_ = other.pokedexWeightKg_;
-            parentPokemonId_ = other.parentPokemonId_;
-            heightStdDev_ = other.heightStdDev_;
-            weightStdDev_ = other.weightStdDev_;
-            kmDistanceToHatch_ = other.kmDistanceToHatch_;
-            familyId_ = other.familyId_;
-            candyToEvolve_ = other.candyToEvolve_;
-        }
-
-        public static pb::MessageParser<PokemonSettings> Parser
-        {
-            get { return _parser; }
-        }
-
-        public static pbr::MessageDescriptor Descriptor
-        {
-            get { return global::PokemonGo.RocketAPI.GeneratedCode.PayloadsReflection.Descriptor.MessageTypes[79]; }
-        }
-
-        public global::PokemonGo.RocketAPI.GeneratedCode.PokemonId PokemonId
-        {
-            get { return pokemonId_; }
-            set { pokemonId_ = value; }
-        }
-
-        public float ModelScale
-        {
-            get { return modelScale_; }
-            set { modelScale_ = value; }
-        }
-
-        public global::PokemonGo.RocketAPI.GeneratedCode.PokemonType Type
-        {
-            get { return type_; }
-            set { type_ = value; }
-        }
-
-        public global::PokemonGo.RocketAPI.GeneratedCode.PokemonType Type2
-        {
-            get { return type2_; }
-            set { type2_ = value; }
-        }
-
-        public global::PokemonGo.RocketAPI.GeneratedCode.CameraAttributes Camera
-        {
-            get { return camera_; }
-            set { camera_ = value; }
-        }
-
-        public global::PokemonGo.RocketAPI.GeneratedCode.EncounterAttributes Encounter
-        {
-            get { return encounter_; }
-            set { encounter_ = value; }
-        }
-
-        public global::PokemonGo.RocketAPI.GeneratedCode.StatsAttributes Stats
-        {
-            get { return stats_; }
-            set { stats_ = value; }
-        }
-
-        public pbc::RepeatedField<global::PokemonGo.RocketAPI.GeneratedCode.PokemonMove> QuickMoves
-        {
-            get { return quickMoves_; }
-        }
-
-        public pbc::RepeatedField<global::PokemonGo.RocketAPI.GeneratedCode.PokemonMove> CinematicMoves
-        {
-            get { return cinematicMoves_; }
-        }
-
-        public pbc::RepeatedField<float> AnimationTime
-        {
-            get { return animationTime_; }
-        }
-
-        public pbc::RepeatedField<global::PokemonGo.RocketAPI.GeneratedCode.PokemonId> EvolutionIds
-        {
-            get { return evolutionIds_; }
-        }
-
-        public int EvolutionPips
-        {
-            get { return evolutionPips_; }
-            set { evolutionPips_ = value; }
-        }
-
-        public global::PokemonGo.RocketAPI.GeneratedCode.PokemonClass Class
-        {
-            get { return class_; }
-            set { class_ = value; }
-        }
-
-        public float PokedexHeightM
-        {
-            get { return pokedexHeightM_; }
-            set { pokedexHeightM_ = value; }
-        }
-
-        public float PokedexWeightKg
-        {
-            get { return pokedexWeightKg_; }
-            set { pokedexWeightKg_ = value; }
-        }
-
-        public global::PokemonGo.RocketAPI.GeneratedCode.PokemonId ParentPokemonId
-        {
-            get { return parentPokemonId_; }
-            set { parentPokemonId_ = value; }
-        }
-
-        public float HeightStdDev
-        {
-            get { return heightStdDev_; }
-            set { heightStdDev_ = value; }
-        }
-
-        public float WeightStdDev
-        {
-            get { return weightStdDev_; }
-            set { weightStdDev_ = value; }
-        }
-
-        public float KmDistanceToHatch
-        {
-            get { return kmDistanceToHatch_; }
-            set { kmDistanceToHatch_ = value; }
-        }
-
-        public global::PokemonGo.RocketAPI.GeneratedCode.PokemonFamilyId FamilyId
-        {
-            get { return familyId_; }
-            set { familyId_ = value; }
-        }
-
-        public int CandyToEvolve
-        {
-            get { return candyToEvolve_; }
-            set { candyToEvolve_ = value; }
-        }
-
-        pbr::MessageDescriptor pb::IMessage.Descriptor
-        {
-            get { return Descriptor; }
-        }
-
-        public PokemonSettings Clone()
-        {
-            return new PokemonSettings(this);
-        }
-
-        public bool Equals(PokemonSettings other)
-        {
-            if (ReferenceEquals(other, null))
-            {
-                return false;
-            }
-            if (ReferenceEquals(other, this))
-            {
-                return true;
-            }
-            if (PokemonId != other.PokemonId) return false;
-            if (ModelScale != other.ModelScale) return false;
-            if (Type != other.Type) return false;
-            if (Type2 != other.Type2) return false;
-            if (!Equals(Camera, other.Camera)) return false;
-            if (!Equals(Encounter, other.Encounter)) return false;
-            if (!Equals(Stats, other.Stats)) return false;
-            if (!quickMoves_.Equals(other.quickMoves_)) return false;
-            if (!cinematicMoves_.Equals(other.cinematicMoves_)) return false;
-            if (!animationTime_.Equals(other.animationTime_)) return false;
-            if (!evolutionIds_.Equals(other.evolutionIds_)) return false;
-            if (EvolutionPips != other.EvolutionPips) return false;
-            if (Class != other.Class) return false;
-            if (PokedexHeightM != other.PokedexHeightM) return false;
-            if (PokedexWeightKg != other.PokedexWeightKg) return false;
-            if (ParentPokemonId != other.ParentPokemonId) return false;
-            if (HeightStdDev != other.HeightStdDev) return false;
-            if (WeightStdDev != other.WeightStdDev) return false;
-            if (KmDistanceToHatch != other.KmDistanceToHatch) return false;
-            if (FamilyId != other.FamilyId) return false;
-            if (CandyToEvolve != other.CandyToEvolve) return false;
-            return true;
-        }
-
-        public void WriteTo(pb::CodedOutputStream output)
-        {
-            if (PokemonId != 0)
-            {
-                output.WriteRawTag(8);
-                output.WriteEnum((int)PokemonId);
-            }
-            if (ModelScale != 0F)
-            {
-                output.WriteRawTag(29);
-                output.WriteFloat(ModelScale);
-            }
-            if (Type != 0)
-            {
-                output.WriteRawTag(32);
-                output.WriteEnum((int)Type);
-            }
-            if (Type2 != 0)
-            {
-                output.WriteRawTag(40);
-                output.WriteEnum((int)Type2);
-            }
-            if (camera_ != null)
-            {
-                output.WriteRawTag(50);
-                output.WriteMessage(Camera);
-            }
-            if (encounter_ != null)
-            {
-                output.WriteRawTag(58);
-                output.WriteMessage(Encounter);
-            }
-            if (stats_ != null)
-            {
-                output.WriteRawTag(66);
-                output.WriteMessage(Stats);
-            }
-            quickMoves_.WriteTo(output, _repeated_quickMoves_codec);
-            cinematicMoves_.WriteTo(output, _repeated_cinematicMoves_codec);
-            animationTime_.WriteTo(output, _repeated_animationTime_codec);
-            evolutionIds_.WriteTo(output, _repeated_evolutionIds_codec);
-            if (EvolutionPips != 0)
-            {
-                output.WriteRawTag(104);
-                output.WriteInt32(EvolutionPips);
-            }
-            if (Class != 0)
-            {
-                output.WriteRawTag(112);
-                output.WriteEnum((int)Class);
-            }
-            if (PokedexHeightM != 0F)
-            {
-                output.WriteRawTag(125);
-                output.WriteFloat(PokedexHeightM);
-            }
-            if (PokedexWeightKg != 0F)
-            {
-                output.WriteRawTag(133, 1);
-                output.WriteFloat(PokedexWeightKg);
-            }
-            if (ParentPokemonId != 0)
-            {
-                output.WriteRawTag(136, 1);
-                output.WriteEnum((int)ParentPokemonId);
-            }
-            if (HeightStdDev != 0F)
-            {
-                output.WriteRawTag(149, 1);
-                output.WriteFloat(HeightStdDev);
-            }
-            if (WeightStdDev != 0F)
-            {
-                output.WriteRawTag(157, 1);
-                output.WriteFloat(WeightStdDev);
-            }
-            if (KmDistanceToHatch != 0F)
-            {
-                output.WriteRawTag(165, 1);
-                output.WriteFloat(KmDistanceToHatch);
-            }
-            if (FamilyId != 0)
-            {
-                output.WriteRawTag(168, 1);
-                output.WriteEnum((int)FamilyId);
-            }
-            if (CandyToEvolve != 0)
-            {
-                output.WriteRawTag(176, 1);
-                output.WriteInt32(CandyToEvolve);
-            }
-        }
-
-        public int CalculateSize()
-        {
-            var size = 0;
-            if (PokemonId != 0)
-            {
-                size += 1 + pb::CodedOutputStream.ComputeEnumSize((int)PokemonId);
-            }
-            if (ModelScale != 0F)
-            {
-                size += 1 + 4;
-            }
-            if (Type != 0)
-            {
-                size += 1 + pb::CodedOutputStream.ComputeEnumSize((int)Type);
-            }
-            if (Type2 != 0)
-            {
-                size += 1 + pb::CodedOutputStream.ComputeEnumSize((int)Type2);
-            }
-            if (camera_ != null)
-            {
-                size += 1 + pb::CodedOutputStream.ComputeMessageSize(Camera);
-            }
-            if (encounter_ != null)
-            {
-                size += 1 + pb::CodedOutputStream.ComputeMessageSize(Encounter);
-            }
-            if (stats_ != null)
-            {
-                size += 1 + pb::CodedOutputStream.ComputeMessageSize(Stats);
-            }
-            size += quickMoves_.CalculateSize(_repeated_quickMoves_codec);
-            size += cinematicMoves_.CalculateSize(_repeated_cinematicMoves_codec);
-            size += animationTime_.CalculateSize(_repeated_animationTime_codec);
-            size += evolutionIds_.CalculateSize(_repeated_evolutionIds_codec);
-            if (EvolutionPips != 0)
-            {
-                size += 1 + pb::CodedOutputStream.ComputeInt32Size(EvolutionPips);
-            }
-            if (Class != 0)
-            {
-                size += 1 + pb::CodedOutputStream.ComputeEnumSize((int)Class);
-            }
-            if (PokedexHeightM != 0F)
-            {
-                size += 1 + 4;
-            }
-            if (PokedexWeightKg != 0F)
-            {
-                size += 2 + 4;
-            }
-            if (ParentPokemonId != 0)
-            {
-                size += 2 + pb::CodedOutputStream.ComputeEnumSize((int)ParentPokemonId);
-            }
-            if (HeightStdDev != 0F)
-            {
-                size += 2 + 4;
-            }
-            if (WeightStdDev != 0F)
-            {
-                size += 2 + 4;
-            }
-            if (KmDistanceToHatch != 0F)
-            {
-                size += 2 + 4;
-            }
-            if (FamilyId != 0)
-            {
-                size += 2 + pb::CodedOutputStream.ComputeEnumSize((int)FamilyId);
-            }
-            if (CandyToEvolve != 0)
-            {
-                size += 2 + pb::CodedOutputStream.ComputeInt32Size(CandyToEvolve);
-            }
-            return size;
-        }
-
-        public void MergeFrom(PokemonSettings other)
-        {
-            if (other == null)
-            {
-                return;
-            }
-            if (other.PokemonId != 0)
-            {
-                PokemonId = other.PokemonId;
-            }
-            if (other.ModelScale != 0F)
-            {
-                ModelScale = other.ModelScale;
-            }
-            if (other.Type != 0)
-            {
-                Type = other.Type;
-            }
-            if (other.Type2 != 0)
-            {
-                Type2 = other.Type2;
-            }
-            if (other.camera_ != null)
-            {
-                if (camera_ == null)
-                {
-                    camera_ = new global::PokemonGo.RocketAPI.GeneratedCode.CameraAttributes();
-                }
-                Camera.MergeFrom(other.Camera);
-            }
-            if (other.encounter_ != null)
-            {
-                if (encounter_ == null)
-                {
-                    encounter_ = new global::PokemonGo.RocketAPI.GeneratedCode.EncounterAttributes();
-                }
-                Encounter.MergeFrom(other.Encounter);
-            }
-            if (other.stats_ != null)
-            {
-                if (stats_ == null)
-                {
-                    stats_ = new global::PokemonGo.RocketAPI.GeneratedCode.StatsAttributes();
-                }
-                Stats.MergeFrom(other.Stats);
-            }
-            quickMoves_.Add(other.quickMoves_);
-            cinematicMoves_.Add(other.cinematicMoves_);
-            animationTime_.Add(other.animationTime_);
-            evolutionIds_.Add(other.evolutionIds_);
-            if (other.EvolutionPips != 0)
-            {
-                EvolutionPips = other.EvolutionPips;
-            }
-            if (other.Class != 0)
-            {
-                Class = other.Class;
-            }
-            if (other.PokedexHeightM != 0F)
-            {
-                PokedexHeightM = other.PokedexHeightM;
-            }
-            if (other.PokedexWeightKg != 0F)
-            {
-                PokedexWeightKg = other.PokedexWeightKg;
-            }
-            if (other.ParentPokemonId != 0)
-            {
-                ParentPokemonId = other.ParentPokemonId;
-            }
-            if (other.HeightStdDev != 0F)
-            {
-                HeightStdDev = other.HeightStdDev;
-            }
-            if (other.WeightStdDev != 0F)
-            {
-                WeightStdDev = other.WeightStdDev;
-            }
-            if (other.KmDistanceToHatch != 0F)
-            {
-                KmDistanceToHatch = other.KmDistanceToHatch;
-            }
-            if (other.FamilyId != 0)
-            {
-                FamilyId = other.FamilyId;
-            }
-            if (other.CandyToEvolve != 0)
-            {
-                CandyToEvolve = other.CandyToEvolve;
-            }
-        }
-
-        public void MergeFrom(pb::CodedInputStream input)
-        {
-            uint tag;
-            while ((tag = input.ReadTag()) != 0)
-            {
-                switch (tag)
-                {
-                    default:
-                        input.SkipLastField();
-                        break;
-                    case 8:
-                        {
-                            pokemonId_ = (global::PokemonGo.RocketAPI.GeneratedCode.PokemonId)input.ReadEnum();
-                            break;
-                        }
-                    case 29:
-                        {
-                            ModelScale = input.ReadFloat();
-                            break;
-                        }
-                    case 32:
-                        {
-                            type_ = (global::PokemonGo.RocketAPI.GeneratedCode.PokemonType)input.ReadEnum();
-                            break;
-                        }
-                    case 40:
-                        {
-                            type2_ = (global::PokemonGo.RocketAPI.GeneratedCode.PokemonType)input.ReadEnum();
-                            break;
-                        }
-                    case 50:
-                        {
-                            if (camera_ == null)
-                            {
-                                camera_ = new global::PokemonGo.RocketAPI.GeneratedCode.CameraAttributes();
-                            }
-                            input.ReadMessage(camera_);
-                            break;
-                        }
-                    case 58:
-                        {
-                            if (encounter_ == null)
-                            {
-                                encounter_ = new global::PokemonGo.RocketAPI.GeneratedCode.EncounterAttributes();
-                            }
-                            input.ReadMessage(encounter_);
-                            break;
-                        }
-                    case 66:
-                        {
-                            if (stats_ == null)
-                            {
-                                stats_ = new global::PokemonGo.RocketAPI.GeneratedCode.StatsAttributes();
-                            }
-                            input.ReadMessage(stats_);
-                            break;
-                        }
-                    case 74:
-                    case 72:
-                        {
-                            quickMoves_.AddEntriesFrom(input, _repeated_quickMoves_codec);
-                            break;
-                        }
-                    case 82:
-                    case 80:
-                        {
-                            cinematicMoves_.AddEntriesFrom(input, _repeated_cinematicMoves_codec);
-                            break;
-                        }
-                    case 90:
-                    case 93:
-                        {
-                            animationTime_.AddEntriesFrom(input, _repeated_animationTime_codec);
-                            break;
-                        }
-                    case 98:
-                    case 96:
-                        {
-                            evolutionIds_.AddEntriesFrom(input, _repeated_evolutionIds_codec);
-                            break;
-                        }
-                    case 104:
-                        {
-                            EvolutionPips = input.ReadInt32();
-                            break;
-                        }
-                    case 112:
-                        {
-                            class_ = (global::PokemonGo.RocketAPI.GeneratedCode.PokemonClass)input.ReadEnum();
-                            break;
-                        }
-                    case 125:
-                        {
-                            PokedexHeightM = input.ReadFloat();
-                            break;
-                        }
-                    case 133:
-                        {
-                            PokedexWeightKg = input.ReadFloat();
-                            break;
-                        }
-                    case 136:
-                        {
-                            parentPokemonId_ = (global::PokemonGo.RocketAPI.GeneratedCode.PokemonId)input.ReadEnum();
-                            break;
-                        }
-                    case 149:
-                        {
-                            HeightStdDev = input.ReadFloat();
-                            break;
-                        }
-                    case 157:
-                        {
-                            WeightStdDev = input.ReadFloat();
-                            break;
-                        }
-                    case 165:
-                        {
-                            KmDistanceToHatch = input.ReadFloat();
-                            break;
-                        }
-                    case 168:
-                        {
-                            familyId_ = (global::PokemonGo.RocketAPI.GeneratedCode.PokemonFamilyId)input.ReadEnum();
-                            break;
-                        }
-                    case 176:
-                        {
-                            CandyToEvolve = input.ReadInt32();
-                            break;
-                        }
-                }
-            }
-        }
-
-        public override bool Equals(object other)
-        {
-            return Equals(other as PokemonSettings);
-        }
-
-        public override int GetHashCode()
-        {
-            var hash = 1;
-            if (PokemonId != 0) hash ^= PokemonId.GetHashCode();
-            if (ModelScale != 0F) hash ^= ModelScale.GetHashCode();
-            if (Type != 0) hash ^= Type.GetHashCode();
-            if (Type2 != 0) hash ^= Type2.GetHashCode();
-            if (camera_ != null) hash ^= Camera.GetHashCode();
-            if (encounter_ != null) hash ^= Encounter.GetHashCode();
-            if (stats_ != null) hash ^= Stats.GetHashCode();
-            hash ^= quickMoves_.GetHashCode();
-            hash ^= cinematicMoves_.GetHashCode();
-            hash ^= animationTime_.GetHashCode();
-            hash ^= evolutionIds_.GetHashCode();
-            if (EvolutionPips != 0) hash ^= EvolutionPips.GetHashCode();
-            if (Class != 0) hash ^= Class.GetHashCode();
-            if (PokedexHeightM != 0F) hash ^= PokedexHeightM.GetHashCode();
-            if (PokedexWeightKg != 0F) hash ^= PokedexWeightKg.GetHashCode();
-            if (ParentPokemonId != 0) hash ^= ParentPokemonId.GetHashCode();
-            if (HeightStdDev != 0F) hash ^= HeightStdDev.GetHashCode();
-            if (WeightStdDev != 0F) hash ^= WeightStdDev.GetHashCode();
-            if (KmDistanceToHatch != 0F) hash ^= KmDistanceToHatch.GetHashCode();
-            if (FamilyId != 0) hash ^= FamilyId.GetHashCode();
-            if (CandyToEvolve != 0) hash ^= CandyToEvolve.GetHashCode();
-            return hash;
-        }
-
-        partial void OnConstruction();
-
-        public override string ToString()
-        {
-            return pb::JsonFormatter.ToDiagnosticString(this);
-        }
-    }
-
-    [global::System.Diagnostics.DebuggerNonUserCodeAttribute()]
-    public sealed partial class CameraAttributes : pb::IMessage<CameraAttributes>
-    {
-        /// <summary>Field number for the "disk_radius_m" field.</summary>
-        public const int DiskRadiusMFieldNumber = 1;
-
-        /// <summary>Field number for the "cylinder_radius_m" field.</summary>
-        public const int CylinderRadiusMFieldNumber = 2;
-
-        /// <summary>Field number for the "cylinder_height_m" field.</summary>
-        public const int CylinderHeightMFieldNumber = 3;
-
-        /// <summary>Field number for the "cylinder_ground_m" field.</summary>
-        public const int CylinderGroundMFieldNumber = 4;
-
-        /// <summary>Field number for the "shoulder_mode_scale" field.</summary>
-        public const int ShoulderModeScaleFieldNumber = 5;
-
-        private static readonly pb::MessageParser<CameraAttributes> _parser =
-            new pb::MessageParser<CameraAttributes>(() => new CameraAttributes());
-
-        private float cylinderGroundM_;
-        private float cylinderHeightM_;
-        private float cylinderRadiusM_;
-        private float diskRadiusM_;
-        private float shoulderModeScale_;
-
-        public CameraAttributes()
-        {
-            OnConstruction();
-        }
-
-        public CameraAttributes(CameraAttributes other) : this()
-        {
-            diskRadiusM_ = other.diskRadiusM_;
-            cylinderRadiusM_ = other.cylinderRadiusM_;
-            cylinderHeightM_ = other.cylinderHeightM_;
-            cylinderGroundM_ = other.cylinderGroundM_;
-            shoulderModeScale_ = other.shoulderModeScale_;
-        }
-
-        public static pb::MessageParser<CameraAttributes> Parser
-        {
-            get { return _parser; }
-        }
-
-        public static pbr::MessageDescriptor Descriptor
-        {
-            get { return global::PokemonGo.RocketAPI.GeneratedCode.PayloadsReflection.Descriptor.MessageTypes[80]; }
-        }
-
-        public float DiskRadiusM
-        {
-            get { return diskRadiusM_; }
-            set { diskRadiusM_ = value; }
-        }
-
-        public float CylinderRadiusM
-        {
-            get { return cylinderRadiusM_; }
-            set { cylinderRadiusM_ = value; }
-        }
-
-        public float CylinderHeightM
-        {
-            get { return cylinderHeightM_; }
-            set { cylinderHeightM_ = value; }
-        }
-
-        public float CylinderGroundM
-        {
-            get { return cylinderGroundM_; }
-            set { cylinderGroundM_ = value; }
-        }
-
-        public float ShoulderModeScale
-        {
-            get { return shoulderModeScale_; }
-            set { shoulderModeScale_ = value; }
-        }
-
-        pbr::MessageDescriptor pb::IMessage.Descriptor
-        {
-            get { return Descriptor; }
-        }
-
-        public CameraAttributes Clone()
-        {
-            return new CameraAttributes(this);
-        }
-
-        public bool Equals(CameraAttributes other)
-        {
-            if (ReferenceEquals(other, null))
-            {
-                return false;
-            }
-            if (ReferenceEquals(other, this))
-            {
-                return true;
-            }
-            if (DiskRadiusM != other.DiskRadiusM) return false;
-            if (CylinderRadiusM != other.CylinderRadiusM) return false;
-            if (CylinderHeightM != other.CylinderHeightM) return false;
-            if (CylinderGroundM != other.CylinderGroundM) return false;
-            if (ShoulderModeScale != other.ShoulderModeScale) return false;
-            return true;
-        }
-
-        public void WriteTo(pb::CodedOutputStream output)
-        {
-            if (DiskRadiusM != 0F)
-            {
-                output.WriteRawTag(13);
-                output.WriteFloat(DiskRadiusM);
-            }
-            if (CylinderRadiusM != 0F)
-            {
-                output.WriteRawTag(21);
-                output.WriteFloat(CylinderRadiusM);
-            }
-            if (CylinderHeightM != 0F)
-            {
-                output.WriteRawTag(29);
-                output.WriteFloat(CylinderHeightM);
-            }
-            if (CylinderGroundM != 0F)
-            {
-                output.WriteRawTag(37);
-                output.WriteFloat(CylinderGroundM);
-            }
-            if (ShoulderModeScale != 0F)
-            {
-                output.WriteRawTag(45);
-                output.WriteFloat(ShoulderModeScale);
-            }
-        }
-
-        public int CalculateSize()
-        {
-            var size = 0;
-            if (DiskRadiusM != 0F)
-            {
-                size += 1 + 4;
-            }
-            if (CylinderRadiusM != 0F)
-            {
-                size += 1 + 4;
-            }
-            if (CylinderHeightM != 0F)
-            {
-                size += 1 + 4;
-            }
-            if (CylinderGroundM != 0F)
-            {
-                size += 1 + 4;
-            }
-            if (ShoulderModeScale != 0F)
-            {
-                size += 1 + 4;
-            }
-            return size;
-        }
-
-        public void MergeFrom(CameraAttributes other)
-        {
-            if (other == null)
-            {
-                return;
-            }
-            if (other.DiskRadiusM != 0F)
-            {
-                DiskRadiusM = other.DiskRadiusM;
-            }
-            if (other.CylinderRadiusM != 0F)
-            {
-                CylinderRadiusM = other.CylinderRadiusM;
-            }
-            if (other.CylinderHeightM != 0F)
-            {
-                CylinderHeightM = other.CylinderHeightM;
-            }
-            if (other.CylinderGroundM != 0F)
-            {
-                CylinderGroundM = other.CylinderGroundM;
-            }
-            if (other.ShoulderModeScale != 0F)
-            {
-                ShoulderModeScale = other.ShoulderModeScale;
-            }
-        }
-
-        public void MergeFrom(pb::CodedInputStream input)
-        {
-            uint tag;
-            while ((tag = input.ReadTag()) != 0)
-            {
-                switch (tag)
-                {
-                    default:
-                        input.SkipLastField();
-                        break;
-                    case 13:
-                        {
-                            DiskRadiusM = input.ReadFloat();
-                            break;
-                        }
-                    case 21:
-                        {
-                            CylinderRadiusM = input.ReadFloat();
-                            break;
-                        }
-                    case 29:
-                        {
-                            CylinderHeightM = input.ReadFloat();
-                            break;
-                        }
-                    case 37:
-                        {
-                            CylinderGroundM = input.ReadFloat();
-                            break;
-                        }
-                    case 45:
-                        {
-                            ShoulderModeScale = input.ReadFloat();
-                            break;
-                        }
-                }
-            }
-        }
-
-        public override bool Equals(object other)
-        {
-            return Equals(other as CameraAttributes);
-        }
-
-        public override int GetHashCode()
-        {
-            var hash = 1;
-            if (DiskRadiusM != 0F) hash ^= DiskRadiusM.GetHashCode();
-            if (CylinderRadiusM != 0F) hash ^= CylinderRadiusM.GetHashCode();
-            if (CylinderHeightM != 0F) hash ^= CylinderHeightM.GetHashCode();
-            if (CylinderGroundM != 0F) hash ^= CylinderGroundM.GetHashCode();
-            if (ShoulderModeScale != 0F) hash ^= ShoulderModeScale.GetHashCode();
-            return hash;
-        }
-
-        partial void OnConstruction();
-
-        public override string ToString()
-        {
-            return pb::JsonFormatter.ToDiagnosticString(this);
-        }
-    }
-
-    [global::System.Diagnostics.DebuggerNonUserCodeAttribute()]
-    public sealed partial class EncounterAttributes : pb::IMessage<EncounterAttributes>
-    {
-        /// <summary>Field number for the "base_capture_rate" field.</summary>
-        public const int BaseCaptureRateFieldNumber = 1;
-
-        /// <summary>Field number for the "base_flee_rate" field.</summary>
-        public const int BaseFleeRateFieldNumber = 2;
-
-        /// <summary>Field number for the "collision_radius_m" field.</summary>
-        public const int CollisionRadiusMFieldNumber = 3;
-
-        /// <summary>Field number for the "collision_height_m" field.</summary>
-        public const int CollisionHeightMFieldNumber = 4;
-
-        /// <summary>Field number for the "collision_head_radius_m" field.</summary>
-        public const int CollisionHeadRadiusMFieldNumber = 5;
-
-        /// <summary>Field number for the "movement_type" field.</summary>
-        public const int MovementTypeFieldNumber = 6;
-
-        /// <summary>Field number for the "movement_timer_s" field.</summary>
-        public const int MovementTimerSFieldNumber = 7;
-
-        /// <summary>Field number for the "jump_time_s" field.</summary>
-        public const int JumpTimeSFieldNumber = 8;
-
-        /// <summary>Field number for the "attack_timer_s" field.</summary>
-        public const int AttackTimerSFieldNumber = 9;
-
-        private static readonly pb::MessageParser<EncounterAttributes> _parser =
-            new pb::MessageParser<EncounterAttributes>(() => new EncounterAttributes());
-
-        private float attackTimerS_;
-        private float baseCaptureRate_;
-        private float baseFleeRate_;
-        private float collisionHeadRadiusM_;
-        private float collisionHeightM_;
-        private float collisionRadiusM_;
-        private float jumpTimeS_;
-        private float movementTimerS_;
-        private global::PokemonGo.RocketAPI.GeneratedCode.PokemonMovementType movementType_ = 0;
-
-        public EncounterAttributes()
-        {
-            OnConstruction();
-        }
-
-        public EncounterAttributes(EncounterAttributes other) : this()
-        {
-            baseCaptureRate_ = other.baseCaptureRate_;
-            baseFleeRate_ = other.baseFleeRate_;
-            collisionRadiusM_ = other.collisionRadiusM_;
-            collisionHeightM_ = other.collisionHeightM_;
-            collisionHeadRadiusM_ = other.collisionHeadRadiusM_;
-            movementType_ = other.movementType_;
-            movementTimerS_ = other.movementTimerS_;
-            jumpTimeS_ = other.jumpTimeS_;
-            attackTimerS_ = other.attackTimerS_;
-        }
-
-        public static pb::MessageParser<EncounterAttributes> Parser
-        {
-            get { return _parser; }
-        }
-
-        public static pbr::MessageDescriptor Descriptor
-        {
-            get { return global::PokemonGo.RocketAPI.GeneratedCode.PayloadsReflection.Descriptor.MessageTypes[81]; }
-        }
-
-        public float BaseCaptureRate
-        {
-            get { return baseCaptureRate_; }
-            set { baseCaptureRate_ = value; }
-        }
-
-        public float BaseFleeRate
-        {
-            get { return baseFleeRate_; }
-            set { baseFleeRate_ = value; }
-        }
-
-        public float CollisionRadiusM
-        {
-            get { return collisionRadiusM_; }
-            set { collisionRadiusM_ = value; }
-        }
-
-        public float CollisionHeightM
-        {
-            get { return collisionHeightM_; }
-            set { collisionHeightM_ = value; }
-        }
-
-        public float CollisionHeadRadiusM
-        {
-            get { return collisionHeadRadiusM_; }
-            set { collisionHeadRadiusM_ = value; }
-        }
-
-        public global::PokemonGo.RocketAPI.GeneratedCode.PokemonMovementType MovementType
-        {
-            get { return movementType_; }
-            set { movementType_ = value; }
-        }
-
-        public float MovementTimerS
-        {
-            get { return movementTimerS_; }
-            set { movementTimerS_ = value; }
-        }
-
-        public float JumpTimeS
-        {
-            get { return jumpTimeS_; }
-            set { jumpTimeS_ = value; }
-        }
-
-        public float AttackTimerS
-        {
-            get { return attackTimerS_; }
-            set { attackTimerS_ = value; }
-        }
-
-        pbr::MessageDescriptor pb::IMessage.Descriptor
-        {
-            get { return Descriptor; }
-        }
-
-        public EncounterAttributes Clone()
-        {
-            return new EncounterAttributes(this);
-        }
-
-        public bool Equals(EncounterAttributes other)
-        {
-            if (ReferenceEquals(other, null))
-            {
-                return false;
-            }
-            if (ReferenceEquals(other, this))
-            {
-                return true;
-            }
-            if (BaseCaptureRate != other.BaseCaptureRate) return false;
-            if (BaseFleeRate != other.BaseFleeRate) return false;
-            if (CollisionRadiusM != other.CollisionRadiusM) return false;
-            if (CollisionHeightM != other.CollisionHeightM) return false;
-            if (CollisionHeadRadiusM != other.CollisionHeadRadiusM) return false;
-            if (MovementType != other.MovementType) return false;
-            if (MovementTimerS != other.MovementTimerS) return false;
-            if (JumpTimeS != other.JumpTimeS) return false;
-            if (AttackTimerS != other.AttackTimerS) return false;
-            return true;
-        }
-
-        public void WriteTo(pb::CodedOutputStream output)
-        {
-            if (BaseCaptureRate != 0F)
-            {
-                output.WriteRawTag(13);
-                output.WriteFloat(BaseCaptureRate);
-            }
-            if (BaseFleeRate != 0F)
-            {
-                output.WriteRawTag(21);
-                output.WriteFloat(BaseFleeRate);
-            }
-            if (CollisionRadiusM != 0F)
-            {
-                output.WriteRawTag(29);
-                output.WriteFloat(CollisionRadiusM);
-            }
-            if (CollisionHeightM != 0F)
-            {
-                output.WriteRawTag(37);
-                output.WriteFloat(CollisionHeightM);
-            }
-            if (CollisionHeadRadiusM != 0F)
-            {
-                output.WriteRawTag(45);
-                output.WriteFloat(CollisionHeadRadiusM);
-            }
-            if (MovementType != 0)
-            {
-                output.WriteRawTag(48);
-                output.WriteEnum((int)MovementType);
-            }
-            if (MovementTimerS != 0F)
-            {
-                output.WriteRawTag(61);
-                output.WriteFloat(MovementTimerS);
-            }
-            if (JumpTimeS != 0F)
-            {
-                output.WriteRawTag(69);
-                output.WriteFloat(JumpTimeS);
-            }
-            if (AttackTimerS != 0F)
-            {
-                output.WriteRawTag(77);
-                output.WriteFloat(AttackTimerS);
-            }
-        }
-
-        public int CalculateSize()
-        {
-            var size = 0;
-            if (BaseCaptureRate != 0F)
-            {
-                size += 1 + 4;
-            }
-            if (BaseFleeRate != 0F)
-            {
-                size += 1 + 4;
-            }
-            if (CollisionRadiusM != 0F)
-            {
-                size += 1 + 4;
-            }
-            if (CollisionHeightM != 0F)
-            {
-                size += 1 + 4;
-            }
-            if (CollisionHeadRadiusM != 0F)
-            {
-                size += 1 + 4;
-            }
-            if (MovementType != 0)
-            {
-                size += 1 + pb::CodedOutputStream.ComputeEnumSize((int)MovementType);
-            }
-            if (MovementTimerS != 0F)
-            {
-                size += 1 + 4;
-            }
-            if (JumpTimeS != 0F)
-            {
-                size += 1 + 4;
-            }
-            if (AttackTimerS != 0F)
-            {
-                size += 1 + 4;
-            }
-            return size;
-        }
-
-        public void MergeFrom(EncounterAttributes other)
-        {
-            if (other == null)
-            {
-                return;
-            }
-            if (other.BaseCaptureRate != 0F)
-            {
-                BaseCaptureRate = other.BaseCaptureRate;
-            }
-            if (other.BaseFleeRate != 0F)
-            {
-                BaseFleeRate = other.BaseFleeRate;
-            }
-            if (other.CollisionRadiusM != 0F)
-            {
-                CollisionRadiusM = other.CollisionRadiusM;
-            }
-            if (other.CollisionHeightM != 0F)
-            {
-                CollisionHeightM = other.CollisionHeightM;
-            }
-            if (other.CollisionHeadRadiusM != 0F)
-            {
-                CollisionHeadRadiusM = other.CollisionHeadRadiusM;
-            }
-            if (other.MovementType != 0)
-            {
-                MovementType = other.MovementType;
-            }
-            if (other.MovementTimerS != 0F)
-            {
-                MovementTimerS = other.MovementTimerS;
-            }
-            if (other.JumpTimeS != 0F)
-            {
-                JumpTimeS = other.JumpTimeS;
-            }
-            if (other.AttackTimerS != 0F)
-            {
-                AttackTimerS = other.AttackTimerS;
-            }
-        }
-
-        public void MergeFrom(pb::CodedInputStream input)
-        {
-            uint tag;
-            while ((tag = input.ReadTag()) != 0)
-            {
-                switch (tag)
-                {
-                    default:
-                        input.SkipLastField();
-                        break;
-                    case 13:
-                        {
-                            BaseCaptureRate = input.ReadFloat();
-                            break;
-                        }
-                    case 21:
-                        {
-                            BaseFleeRate = input.ReadFloat();
-                            break;
-                        }
-                    case 29:
-                        {
-                            CollisionRadiusM = input.ReadFloat();
-                            break;
-                        }
-                    case 37:
-                        {
-                            CollisionHeightM = input.ReadFloat();
-                            break;
-                        }
-                    case 45:
-                        {
-                            CollisionHeadRadiusM = input.ReadFloat();
-                            break;
-                        }
-                    case 48:
-                        {
-                            movementType_ = (global::PokemonGo.RocketAPI.GeneratedCode.PokemonMovementType)input.ReadEnum();
-                            break;
-                        }
-                    case 61:
-                        {
-                            MovementTimerS = input.ReadFloat();
-                            break;
-                        }
-                    case 69:
-                        {
-                            JumpTimeS = input.ReadFloat();
-                            break;
-                        }
-                    case 77:
-                        {
-                            AttackTimerS = input.ReadFloat();
-                            break;
-                        }
-                }
-            }
-        }
-
-        public override bool Equals(object other)
-        {
-            return Equals(other as EncounterAttributes);
-        }
-
-        public override int GetHashCode()
-        {
-            var hash = 1;
-            if (BaseCaptureRate != 0F) hash ^= BaseCaptureRate.GetHashCode();
-            if (BaseFleeRate != 0F) hash ^= BaseFleeRate.GetHashCode();
-            if (CollisionRadiusM != 0F) hash ^= CollisionRadiusM.GetHashCode();
-            if (CollisionHeightM != 0F) hash ^= CollisionHeightM.GetHashCode();
-            if (CollisionHeadRadiusM != 0F) hash ^= CollisionHeadRadiusM.GetHashCode();
-            if (MovementType != 0) hash ^= MovementType.GetHashCode();
-            if (MovementTimerS != 0F) hash ^= MovementTimerS.GetHashCode();
-            if (JumpTimeS != 0F) hash ^= JumpTimeS.GetHashCode();
-            if (AttackTimerS != 0F) hash ^= AttackTimerS.GetHashCode();
-            return hash;
-        }
-
-        partial void OnConstruction();
-
-        public override string ToString()
-        {
-            return pb::JsonFormatter.ToDiagnosticString(this);
-        }
-    }
-
-    [global::System.Diagnostics.DebuggerNonUserCodeAttribute()]
-    public sealed partial class StatsAttributes : pb::IMessage<StatsAttributes>
-    {
-        /// <summary>Field number for the "base_stamina" field.</summary>
-        public const int BaseStaminaFieldNumber = 1;
-
-        /// <summary>Field number for the "base_attack" field.</summary>
-        public const int BaseAttackFieldNumber = 2;
-
-        /// <summary>Field number for the "base_defense" field.</summary>
-        public const int BaseDefenseFieldNumber = 3;
-
-        /// <summary>Field number for the "dodge_energy_delta" field.</summary>
-        public const int DodgeEnergyDeltaFieldNumber = 8;
-
-        private static readonly pb::MessageParser<StatsAttributes> _parser =
-            new pb::MessageParser<StatsAttributes>(() => new StatsAttributes());
-
-        private int baseAttack_;
-        private int baseDefense_;
-        private int baseStamina_;
-        private int dodgeEnergyDelta_;
-
-        public StatsAttributes()
-        {
-            OnConstruction();
-        }
-
-        public StatsAttributes(StatsAttributes other) : this()
-        {
-            baseStamina_ = other.baseStamina_;
-            baseAttack_ = other.baseAttack_;
-            baseDefense_ = other.baseDefense_;
-            dodgeEnergyDelta_ = other.dodgeEnergyDelta_;
-        }
-
-        public static pb::MessageParser<StatsAttributes> Parser
-        {
-            get { return _parser; }
-        }
-
-        public static pbr::MessageDescriptor Descriptor
-        {
-            get { return global::PokemonGo.RocketAPI.GeneratedCode.PayloadsReflection.Descriptor.MessageTypes[82]; }
-        }
-
-        public int BaseStamina
-        {
-            get { return baseStamina_; }
-            set { baseStamina_ = value; }
-        }
-
-        public int BaseAttack
-        {
-            get { return baseAttack_; }
-            set { baseAttack_ = value; }
-        }
-
-        public int BaseDefense
-        {
-            get { return baseDefense_; }
-            set { baseDefense_ = value; }
-        }
-
-        public int DodgeEnergyDelta
-        {
-            get { return dodgeEnergyDelta_; }
-            set { dodgeEnergyDelta_ = value; }
-        }
-
-        pbr::MessageDescriptor pb::IMessage.Descriptor
-        {
-            get { return Descriptor; }
-        }
-
-        public StatsAttributes Clone()
-        {
-            return new StatsAttributes(this);
-        }
-
-        public bool Equals(StatsAttributes other)
-        {
-            if (ReferenceEquals(other, null))
-            {
-                return false;
-            }
-            if (ReferenceEquals(other, this))
-            {
-                return true;
-            }
-            if (BaseStamina != other.BaseStamina) return false;
-            if (BaseAttack != other.BaseAttack) return false;
-            if (BaseDefense != other.BaseDefense) return false;
-            if (DodgeEnergyDelta != other.DodgeEnergyDelta) return false;
-            return true;
-        }
-
-        public void WriteTo(pb::CodedOutputStream output)
-        {
-            if (BaseStamina != 0)
-            {
-                output.WriteRawTag(8);
-                output.WriteInt32(BaseStamina);
-            }
-            if (BaseAttack != 0)
-            {
-                output.WriteRawTag(16);
-                output.WriteInt32(BaseAttack);
-            }
-            if (BaseDefense != 0)
-            {
-                output.WriteRawTag(24);
-                output.WriteInt32(BaseDefense);
-            }
-            if (DodgeEnergyDelta != 0)
-            {
-                output.WriteRawTag(64);
-                output.WriteInt32(DodgeEnergyDelta);
-            }
-        }
-
-        public int CalculateSize()
-        {
-            var size = 0;
-            if (BaseStamina != 0)
-            {
-                size += 1 + pb::CodedOutputStream.ComputeInt32Size(BaseStamina);
-            }
-            if (BaseAttack != 0)
-            {
-                size += 1 + pb::CodedOutputStream.ComputeInt32Size(BaseAttack);
-            }
-            if (BaseDefense != 0)
-            {
-                size += 1 + pb::CodedOutputStream.ComputeInt32Size(BaseDefense);
-            }
-            if (DodgeEnergyDelta != 0)
-            {
-                size += 1 + pb::CodedOutputStream.ComputeInt32Size(DodgeEnergyDelta);
-            }
-            return size;
-        }
-
-        public void MergeFrom(StatsAttributes other)
-        {
-            if (other == null)
-            {
-                return;
-            }
-            if (other.BaseStamina != 0)
-            {
-                BaseStamina = other.BaseStamina;
-            }
-            if (other.BaseAttack != 0)
-            {
-                BaseAttack = other.BaseAttack;
-            }
-            if (other.BaseDefense != 0)
-            {
-                BaseDefense = other.BaseDefense;
-            }
-            if (other.DodgeEnergyDelta != 0)
-            {
-                DodgeEnergyDelta = other.DodgeEnergyDelta;
-            }
-        }
-
-        public void MergeFrom(pb::CodedInputStream input)
-        {
-            uint tag;
-            while ((tag = input.ReadTag()) != 0)
-            {
-                switch (tag)
-                {
-                    default:
-                        input.SkipLastField();
-                        break;
-                    case 8:
-                        {
-                            BaseStamina = input.ReadInt32();
-                            break;
-                        }
-                    case 16:
-                        {
-                            BaseAttack = input.ReadInt32();
-                            break;
-                        }
-                    case 24:
-                        {
-                            BaseDefense = input.ReadInt32();
-                            break;
-                        }
-                    case 64:
-                        {
-                            DodgeEnergyDelta = input.ReadInt32();
-                            break;
-                        }
-                }
-            }
-        }
-
-        public override bool Equals(object other)
-        {
-            return Equals(other as StatsAttributes);
-        }
-
-        public override int GetHashCode()
-        {
-            var hash = 1;
-            if (BaseStamina != 0) hash ^= BaseStamina.GetHashCode();
-            if (BaseAttack != 0) hash ^= BaseAttack.GetHashCode();
-            if (BaseDefense != 0) hash ^= BaseDefense.GetHashCode();
-            if (DodgeEnergyDelta != 0) hash ^= DodgeEnergyDelta.GetHashCode();
-            return hash;
-        }
-
-        partial void OnConstruction();
-
-        public override string ToString()
-        {
-            return pb::JsonFormatter.ToDiagnosticString(this);
-        }
-    }
-
-    [global::System.Diagnostics.DebuggerNonUserCodeAttribute()]
-    public sealed partial class ItemSettings : pb::IMessage<ItemSettings>
-    {
-        /// <summary>Field number for the "item_id" field.</summary>
-        public const int ItemIdFieldNumber = 1;
-
-        /// <summary>Field number for the "item_type" field.</summary>
-        public const int ItemTypeFieldNumber = 2;
-
-        /// <summary>Field number for the "category" field.</summary>
-        public const int CategoryFieldNumber = 3;
-
-        /// <summary>Field number for the "drop_freq" field.</summary>
-        public const int DropFreqFieldNumber = 4;
-
-        /// <summary>Field number for the "drop_trainer_level" field.</summary>
-        public const int DropTrainerLevelFieldNumber = 5;
-
-        /// <summary>Field number for the "pokeball" field.</summary>
-        public const int PokeballFieldNumber = 6;
-
-        /// <summary>Field number for the "potion" field.</summary>
-        public const int PotionFieldNumber = 7;
-
-        /// <summary>Field number for the "revive" field.</summary>
-        public const int ReviveFieldNumber = 8;
-
-        /// <summary>Field number for the "battle" field.</summary>
-        public const int BattleFieldNumber = 9;
-
-        /// <summary>Field number for the "food" field.</summary>
-        public const int FoodFieldNumber = 10;
-
-        /// <summary>Field number for the "inventory_upgrade" field.</summary>
-        public const int InventoryUpgradeFieldNumber = 11;
-
-        /// <summary>Field number for the "xp_boost" field.</summary>
-        public const int XpBoostFieldNumber = 12;
-
-        /// <summary>Field number for the "incense" field.</summary>
-        public const int IncenseFieldNumber = 13;
-
-        /// <summary>Field number for the "egg_incubator" field.</summary>
-        public const int EggIncubatorFieldNumber = 14;
-
-        /// <summary>Field number for the "fort_modifier" field.</summary>
-        public const int FortModifierFieldNumber = 15;
-
-        private static readonly pb::MessageParser<ItemSettings> _parser =
-            new pb::MessageParser<ItemSettings>(() => new ItemSettings());
-
-        private global::PokemonGo.RocketAPI.GeneratedCode.BattleAttributes battle_;
-        private global::PokemonGo.RocketAPI.GeneratedCode.ItemCategory category_ = 0;
-        private float dropFreq_;
-        private int dropTrainerLevel_;
-        private global::PokemonGo.RocketAPI.GeneratedCode.EggIncubatorAttributes eggIncubator_;
-        private global::PokemonGo.RocketAPI.GeneratedCode.FoodAttributes food_;
-        private global::PokemonGo.RocketAPI.GeneratedCode.FortModifierAttributes fortModifier_;
-        private global::PokemonGo.RocketAPI.GeneratedCode.IncenseAttributes incense_;
-        private global::PokemonGo.RocketAPI.GeneratedCode.InventoryUpgradeAttributes inventoryUpgrade_;
-        private global::PokemonGo.RocketAPI.GeneratedCode.ItemId itemId_ = 0;
-        private global::PokemonGo.RocketAPI.GeneratedCode.ItemType itemType_ = 0;
-        private global::PokemonGo.RocketAPI.GeneratedCode.PokeballAttributes pokeball_;
-        private global::PokemonGo.RocketAPI.GeneratedCode.PotionAttributes potion_;
-        private global::PokemonGo.RocketAPI.GeneratedCode.ReviveAttributes revive_;
-        private global::PokemonGo.RocketAPI.GeneratedCode.ExperienceBoostAttributes xpBoost_;
-
-        public ItemSettings()
-        {
-            OnConstruction();
-        }
-
-        public ItemSettings(ItemSettings other) : this()
-        {
-            itemId_ = other.itemId_;
-            itemType_ = other.itemType_;
-            category_ = other.category_;
-            dropFreq_ = other.dropFreq_;
-            dropTrainerLevel_ = other.dropTrainerLevel_;
-            Pokeball = other.pokeball_ != null ? other.Pokeball.Clone() : null;
-            Potion = other.potion_ != null ? other.Potion.Clone() : null;
-            Revive = other.revive_ != null ? other.Revive.Clone() : null;
-            Battle = other.battle_ != null ? other.Battle.Clone() : null;
-            Food = other.food_ != null ? other.Food.Clone() : null;
-            InventoryUpgrade = other.inventoryUpgrade_ != null ? other.InventoryUpgrade.Clone() : null;
-            XpBoost = other.xpBoost_ != null ? other.XpBoost.Clone() : null;
-            Incense = other.incense_ != null ? other.Incense.Clone() : null;
-            EggIncubator = other.eggIncubator_ != null ? other.EggIncubator.Clone() : null;
-            FortModifier = other.fortModifier_ != null ? other.FortModifier.Clone() : null;
-        }
-
-        public static pb::MessageParser<ItemSettings> Parser
-        {
-            get { return _parser; }
-        }
-
-        public static pbr::MessageDescriptor Descriptor
-        {
-            get { return global::PokemonGo.RocketAPI.GeneratedCode.PayloadsReflection.Descriptor.MessageTypes[83]; }
-        }
-
-        public global::PokemonGo.RocketAPI.GeneratedCode.ItemId ItemId
-        {
-            get { return itemId_; }
-            set { itemId_ = value; }
-        }
-
-        public global::PokemonGo.RocketAPI.GeneratedCode.ItemType ItemType
-        {
-            get { return itemType_; }
-            set { itemType_ = value; }
-        }
-
-        public global::PokemonGo.RocketAPI.GeneratedCode.ItemCategory Category
-        {
-            get { return category_; }
-            set { category_ = value; }
-        }
-
-        public float DropFreq
-        {
-            get { return dropFreq_; }
-            set { dropFreq_ = value; }
-        }
-
-        public int DropTrainerLevel
-        {
-            get { return dropTrainerLevel_; }
-            set { dropTrainerLevel_ = value; }
-        }
-
-        public global::PokemonGo.RocketAPI.GeneratedCode.PokeballAttributes Pokeball
-        {
-            get { return pokeball_; }
-            set { pokeball_ = value; }
-        }
-
-        public global::PokemonGo.RocketAPI.GeneratedCode.PotionAttributes Potion
-        {
-            get { return potion_; }
-            set { potion_ = value; }
-        }
-
-        public global::PokemonGo.RocketAPI.GeneratedCode.ReviveAttributes Revive
-        {
-            get { return revive_; }
-            set { revive_ = value; }
-        }
-
-        public global::PokemonGo.RocketAPI.GeneratedCode.BattleAttributes Battle
-        {
-            get { return battle_; }
-            set { battle_ = value; }
-        }
-
-        public global::PokemonGo.RocketAPI.GeneratedCode.FoodAttributes Food
-        {
-            get { return food_; }
-            set { food_ = value; }
-        }
-
-        public global::PokemonGo.RocketAPI.GeneratedCode.InventoryUpgradeAttributes InventoryUpgrade
-        {
-            get { return inventoryUpgrade_; }
-            set { inventoryUpgrade_ = value; }
-        }
-
-        public global::PokemonGo.RocketAPI.GeneratedCode.ExperienceBoostAttributes XpBoost
-        {
-            get { return xpBoost_; }
-            set { xpBoost_ = value; }
-        }
-
-        public global::PokemonGo.RocketAPI.GeneratedCode.IncenseAttributes Incense
-        {
-            get { return incense_; }
-            set { incense_ = value; }
-        }
-
-        public global::PokemonGo.RocketAPI.GeneratedCode.EggIncubatorAttributes EggIncubator
-        {
-            get { return eggIncubator_; }
-            set { eggIncubator_ = value; }
-        }
-
-        public global::PokemonGo.RocketAPI.GeneratedCode.FortModifierAttributes FortModifier
-        {
-            get { return fortModifier_; }
-            set { fortModifier_ = value; }
-        }
-
-        pbr::MessageDescriptor pb::IMessage.Descriptor
-        {
-            get { return Descriptor; }
-        }
-
-        public ItemSettings Clone()
-        {
-            return new ItemSettings(this);
-        }
-
-        public bool Equals(ItemSettings other)
-        {
-            if (ReferenceEquals(other, null))
-            {
-                return false;
-            }
-            if (ReferenceEquals(other, this))
-            {
-                return true;
-            }
-            if (ItemId != other.ItemId) return false;
-            if (ItemType != other.ItemType) return false;
-            if (Category != other.Category) return false;
-            if (DropFreq != other.DropFreq) return false;
-            if (DropTrainerLevel != other.DropTrainerLevel) return false;
-            if (!Equals(Pokeball, other.Pokeball)) return false;
-            if (!Equals(Potion, other.Potion)) return false;
-            if (!Equals(Revive, other.Revive)) return false;
-            if (!Equals(Battle, other.Battle)) return false;
-            if (!Equals(Food, other.Food)) return false;
-            if (!Equals(InventoryUpgrade, other.InventoryUpgrade)) return false;
-            if (!Equals(XpBoost, other.XpBoost)) return false;
-            if (!Equals(Incense, other.Incense)) return false;
-            if (!Equals(EggIncubator, other.EggIncubator)) return false;
-            if (!Equals(FortModifier, other.FortModifier)) return false;
-            return true;
-        }
-
-        public void WriteTo(pb::CodedOutputStream output)
-        {
-            if (ItemId != 0)
-            {
-                output.WriteRawTag(8);
-                output.WriteEnum((int)ItemId);
-            }
-            if (ItemType != 0)
-            {
-                output.WriteRawTag(16);
-                output.WriteEnum((int)ItemType);
-            }
-            if (Category != 0)
-            {
-                output.WriteRawTag(24);
-                output.WriteEnum((int)Category);
-            }
-            if (DropFreq != 0F)
-            {
-                output.WriteRawTag(37);
-                output.WriteFloat(DropFreq);
-            }
-            if (DropTrainerLevel != 0)
-            {
-                output.WriteRawTag(40);
-                output.WriteInt32(DropTrainerLevel);
-            }
-            if (pokeball_ != null)
-            {
-                output.WriteRawTag(50);
-                output.WriteMessage(Pokeball);
-            }
-            if (potion_ != null)
-            {
-                output.WriteRawTag(58);
-                output.WriteMessage(Potion);
-            }
-            if (revive_ != null)
-            {
-                output.WriteRawTag(66);
-                output.WriteMessage(Revive);
-            }
-            if (battle_ != null)
-            {
-                output.WriteRawTag(74);
-                output.WriteMessage(Battle);
-            }
-            if (food_ != null)
-            {
-                output.WriteRawTag(82);
-                output.WriteMessage(Food);
-            }
-            if (inventoryUpgrade_ != null)
-            {
-                output.WriteRawTag(90);
-                output.WriteMessage(InventoryUpgrade);
-            }
-            if (xpBoost_ != null)
-            {
-                output.WriteRawTag(98);
-                output.WriteMessage(XpBoost);
-            }
-            if (incense_ != null)
-            {
-                output.WriteRawTag(106);
-                output.WriteMessage(Incense);
-            }
-            if (eggIncubator_ != null)
-            {
-                output.WriteRawTag(114);
-                output.WriteMessage(EggIncubator);
-            }
-            if (fortModifier_ != null)
-            {
-                output.WriteRawTag(122);
-                output.WriteMessage(FortModifier);
-            }
-        }
-
-        public int CalculateSize()
-        {
-            var size = 0;
-            if (ItemId != 0)
-            {
-                size += 1 + pb::CodedOutputStream.ComputeEnumSize((int)ItemId);
-            }
-            if (ItemType != 0)
-            {
-                size += 1 + pb::CodedOutputStream.ComputeEnumSize((int)ItemType);
-            }
-            if (Category != 0)
-            {
-                size += 1 + pb::CodedOutputStream.ComputeEnumSize((int)Category);
-            }
-            if (DropFreq != 0F)
-            {
-                size += 1 + 4;
-            }
-            if (DropTrainerLevel != 0)
-            {
-                size += 1 + pb::CodedOutputStream.ComputeInt32Size(DropTrainerLevel);
-            }
-            if (pokeball_ != null)
-            {
-                size += 1 + pb::CodedOutputStream.ComputeMessageSize(Pokeball);
-            }
-            if (potion_ != null)
-            {
-                size += 1 + pb::CodedOutputStream.ComputeMessageSize(Potion);
-            }
-            if (revive_ != null)
-            {
-                size += 1 + pb::CodedOutputStream.ComputeMessageSize(Revive);
-            }
-            if (battle_ != null)
-            {
-                size += 1 + pb::CodedOutputStream.ComputeMessageSize(Battle);
-            }
-            if (food_ != null)
-            {
-                size += 1 + pb::CodedOutputStream.ComputeMessageSize(Food);
-            }
-            if (inventoryUpgrade_ != null)
-            {
-                size += 1 + pb::CodedOutputStream.ComputeMessageSize(InventoryUpgrade);
-            }
-            if (xpBoost_ != null)
-            {
-                size += 1 + pb::CodedOutputStream.ComputeMessageSize(XpBoost);
-            }
-            if (incense_ != null)
-            {
-                size += 1 + pb::CodedOutputStream.ComputeMessageSize(Incense);
-            }
-            if (eggIncubator_ != null)
-            {
-                size += 1 + pb::CodedOutputStream.ComputeMessageSize(EggIncubator);
-            }
-            if (fortModifier_ != null)
-            {
-                size += 1 + pb::CodedOutputStream.ComputeMessageSize(FortModifier);
-            }
-            return size;
-        }
-
-        public void MergeFrom(ItemSettings other)
-        {
-            if (other == null)
-            {
-                return;
-            }
-            if (other.ItemId != 0)
-            {
-                ItemId = other.ItemId;
-            }
-            if (other.ItemType != 0)
-            {
-                ItemType = other.ItemType;
-            }
-            if (other.Category != 0)
-            {
-                Category = other.Category;
-            }
-            if (other.DropFreq != 0F)
-            {
-                DropFreq = other.DropFreq;
-            }
-            if (other.DropTrainerLevel != 0)
-            {
-                DropTrainerLevel = other.DropTrainerLevel;
-            }
-            if (other.pokeball_ != null)
-            {
-                if (pokeball_ == null)
-                {
-                    pokeball_ = new global::PokemonGo.RocketAPI.GeneratedCode.PokeballAttributes();
-                }
-                Pokeball.MergeFrom(other.Pokeball);
-            }
-            if (other.potion_ != null)
-            {
-                if (potion_ == null)
-                {
-                    potion_ = new global::PokemonGo.RocketAPI.GeneratedCode.PotionAttributes();
-                }
-                Potion.MergeFrom(other.Potion);
-            }
-            if (other.revive_ != null)
-            {
-                if (revive_ == null)
-                {
-                    revive_ = new global::PokemonGo.RocketAPI.GeneratedCode.ReviveAttributes();
-                }
-                Revive.MergeFrom(other.Revive);
-            }
-            if (other.battle_ != null)
-            {
-                if (battle_ == null)
-                {
-                    battle_ = new global::PokemonGo.RocketAPI.GeneratedCode.BattleAttributes();
-                }
-                Battle.MergeFrom(other.Battle);
-            }
-            if (other.food_ != null)
-            {
-                if (food_ == null)
-                {
-                    food_ = new global::PokemonGo.RocketAPI.GeneratedCode.FoodAttributes();
-                }
-                Food.MergeFrom(other.Food);
-            }
-            if (other.inventoryUpgrade_ != null)
-            {
-                if (inventoryUpgrade_ == null)
-                {
-                    inventoryUpgrade_ = new global::PokemonGo.RocketAPI.GeneratedCode.InventoryUpgradeAttributes();
-                }
-                InventoryUpgrade.MergeFrom(other.InventoryUpgrade);
-            }
-            if (other.xpBoost_ != null)
-            {
-                if (xpBoost_ == null)
-                {
-                    xpBoost_ = new global::PokemonGo.RocketAPI.GeneratedCode.ExperienceBoostAttributes();
-                }
-                XpBoost.MergeFrom(other.XpBoost);
-            }
-            if (other.incense_ != null)
-            {
-                if (incense_ == null)
-                {
-                    incense_ = new global::PokemonGo.RocketAPI.GeneratedCode.IncenseAttributes();
-                }
-                Incense.MergeFrom(other.Incense);
-            }
-            if (other.eggIncubator_ != null)
-            {
-                if (eggIncubator_ == null)
-                {
-                    eggIncubator_ = new global::PokemonGo.RocketAPI.GeneratedCode.EggIncubatorAttributes();
-                }
-                EggIncubator.MergeFrom(other.EggIncubator);
-            }
-            if (other.fortModifier_ != null)
-            {
-                if (fortModifier_ == null)
-                {
-                    fortModifier_ = new global::PokemonGo.RocketAPI.GeneratedCode.FortModifierAttributes();
-                }
-                FortModifier.MergeFrom(other.FortModifier);
-            }
-        }
-
-        public void MergeFrom(pb::CodedInputStream input)
-        {
-            uint tag;
-            while ((tag = input.ReadTag()) != 0)
-            {
-                switch (tag)
-                {
-                    default:
-                        input.SkipLastField();
-                        break;
-                    case 8:
-                        {
-                            itemId_ = (global::PokemonGo.RocketAPI.GeneratedCode.ItemId)input.ReadEnum();
-                            break;
-                        }
-                    case 16:
-                        {
-                            itemType_ = (global::PokemonGo.RocketAPI.GeneratedCode.ItemType)input.ReadEnum();
-                            break;
-                        }
-                    case 24:
-                        {
-                            category_ = (global::PokemonGo.RocketAPI.GeneratedCode.ItemCategory)input.ReadEnum();
-                            break;
-                        }
-                    case 37:
-                        {
-                            DropFreq = input.ReadFloat();
-                            break;
-                        }
-                    case 40:
-                        {
-                            DropTrainerLevel = input.ReadInt32();
-                            break;
-                        }
-                    case 50:
-                        {
-                            if (pokeball_ == null)
-                            {
-                                pokeball_ = new global::PokemonGo.RocketAPI.GeneratedCode.PokeballAttributes();
-                            }
-                            input.ReadMessage(pokeball_);
-                            break;
-                        }
-                    case 58:
-                        {
-                            if (potion_ == null)
-                            {
-                                potion_ = new global::PokemonGo.RocketAPI.GeneratedCode.PotionAttributes();
-                            }
-                            input.ReadMessage(potion_);
-                            break;
-                        }
-                    case 66:
-                        {
-                            if (revive_ == null)
-                            {
-                                revive_ = new global::PokemonGo.RocketAPI.GeneratedCode.ReviveAttributes();
-                            }
-                            input.ReadMessage(revive_);
-                            break;
-                        }
-                    case 74:
-                        {
-                            if (battle_ == null)
-                            {
-                                battle_ = new global::PokemonGo.RocketAPI.GeneratedCode.BattleAttributes();
-                            }
-                            input.ReadMessage(battle_);
-                            break;
-                        }
-                    case 82:
-                        {
-                            if (food_ == null)
-                            {
-                                food_ = new global::PokemonGo.RocketAPI.GeneratedCode.FoodAttributes();
-                            }
-                            input.ReadMessage(food_);
-                            break;
-                        }
-                    case 90:
-                        {
-                            if (inventoryUpgrade_ == null)
-                            {
-                                inventoryUpgrade_ =
-                                    new global::PokemonGo.RocketAPI.GeneratedCode.InventoryUpgradeAttributes();
-                            }
-                            input.ReadMessage(inventoryUpgrade_);
-                            break;
-                        }
-                    case 98:
-                        {
-                            if (xpBoost_ == null)
-                            {
-                                xpBoost_ = new global::PokemonGo.RocketAPI.GeneratedCode.ExperienceBoostAttributes();
-                            }
-                            input.ReadMessage(xpBoost_);
-                            break;
-                        }
-                    case 106:
-                        {
-                            if (incense_ == null)
-                            {
-                                incense_ = new global::PokemonGo.RocketAPI.GeneratedCode.IncenseAttributes();
-                            }
-                            input.ReadMessage(incense_);
-                            break;
-                        }
-                    case 114:
-                        {
-                            if (eggIncubator_ == null)
-                            {
-                                eggIncubator_ = new global::PokemonGo.RocketAPI.GeneratedCode.EggIncubatorAttributes();
-                            }
-                            input.ReadMessage(eggIncubator_);
-                            break;
-                        }
-                    case 122:
-                        {
-                            if (fortModifier_ == null)
-                            {
-                                fortModifier_ = new global::PokemonGo.RocketAPI.GeneratedCode.FortModifierAttributes();
-                            }
-                            input.ReadMessage(fortModifier_);
-                            break;
-                        }
-                }
-            }
-        }
-
-        public override bool Equals(object other)
-        {
-            return Equals(other as ItemSettings);
-        }
-
-        public override int GetHashCode()
-        {
-            var hash = 1;
-            if (ItemId != 0) hash ^= ItemId.GetHashCode();
-            if (ItemType != 0) hash ^= ItemType.GetHashCode();
-            if (Category != 0) hash ^= Category.GetHashCode();
-            if (DropFreq != 0F) hash ^= DropFreq.GetHashCode();
-            if (DropTrainerLevel != 0) hash ^= DropTrainerLevel.GetHashCode();
-            if (pokeball_ != null) hash ^= Pokeball.GetHashCode();
-            if (potion_ != null) hash ^= Potion.GetHashCode();
-            if (revive_ != null) hash ^= Revive.GetHashCode();
-            if (battle_ != null) hash ^= Battle.GetHashCode();
-            if (food_ != null) hash ^= Food.GetHashCode();
-            if (inventoryUpgrade_ != null) hash ^= InventoryUpgrade.GetHashCode();
-            if (xpBoost_ != null) hash ^= XpBoost.GetHashCode();
-            if (incense_ != null) hash ^= Incense.GetHashCode();
-            if (eggIncubator_ != null) hash ^= EggIncubator.GetHashCode();
-            if (fortModifier_ != null) hash ^= FortModifier.GetHashCode();
-            return hash;
-        }
-
-        partial void OnConstruction();
-
-        public override string ToString()
-        {
-            return pb::JsonFormatter.ToDiagnosticString(this);
-        }
-    }
-
-    [global::System.Diagnostics.DebuggerNonUserCodeAttribute()]
-    public sealed partial class BattleAttributes : pb::IMessage<BattleAttributes>
-    {
-        /// <summary>Field number for the "sta_percent" field.</summary>
-        public const int StaPercentFieldNumber = 1;
-
-        private static readonly pb::MessageParser<BattleAttributes> _parser =
-            new pb::MessageParser<BattleAttributes>(() => new BattleAttributes());
-
-        private float staPercent_;
-
-        public BattleAttributes()
-        {
-            OnConstruction();
-        }
-
-        public BattleAttributes(BattleAttributes other) : this()
-        {
-            staPercent_ = other.staPercent_;
-        }
-
-        public static pb::MessageParser<BattleAttributes> Parser
-        {
-            get { return _parser; }
-        }
-
-        public static pbr::MessageDescriptor Descriptor
-        {
-            get { return global::PokemonGo.RocketAPI.GeneratedCode.PayloadsReflection.Descriptor.MessageTypes[84]; }
-        }
-
-        public float StaPercent
-        {
-            get { return staPercent_; }
-            set { staPercent_ = value; }
-        }
-
-        pbr::MessageDescriptor pb::IMessage.Descriptor
-        {
-            get { return Descriptor; }
-        }
-
-        public BattleAttributes Clone()
-        {
-            return new BattleAttributes(this);
-        }
-
-        public bool Equals(BattleAttributes other)
-        {
-            if (ReferenceEquals(other, null))
-            {
-                return false;
-            }
-            if (ReferenceEquals(other, this))
-            {
-                return true;
-            }
-            if (StaPercent != other.StaPercent) return false;
-            return true;
-        }
-
-        public void WriteTo(pb::CodedOutputStream output)
-        {
-            if (StaPercent != 0F)
-            {
-                output.WriteRawTag(13);
-                output.WriteFloat(StaPercent);
-            }
-        }
-
-        public int CalculateSize()
-        {
-            var size = 0;
-            if (StaPercent != 0F)
-            {
-                size += 1 + 4;
-            }
-            return size;
-        }
-
-        public void MergeFrom(BattleAttributes other)
-        {
-            if (other == null)
-            {
-                return;
-            }
-            if (other.StaPercent != 0F)
-            {
-                StaPercent = other.StaPercent;
-            }
-        }
-
-        public void MergeFrom(pb::CodedInputStream input)
-        {
-            uint tag;
-            while ((tag = input.ReadTag()) != 0)
-            {
-                switch (tag)
-                {
-                    default:
-                        input.SkipLastField();
-                        break;
-                    case 13:
-                        {
-                            StaPercent = input.ReadFloat();
-                            break;
-                        }
-                }
-            }
-        }
-
-        public override bool Equals(object other)
-        {
-            return Equals(other as BattleAttributes);
-        }
-
-        public override int GetHashCode()
-        {
-            var hash = 1;
-            if (StaPercent != 0F) hash ^= StaPercent.GetHashCode();
-            return hash;
-        }
-
-        partial void OnConstruction();
-
-        public override string ToString()
-        {
-            return pb::JsonFormatter.ToDiagnosticString(this);
-        }
-    }
-
-    [global::System.Diagnostics.DebuggerNonUserCodeAttribute()]
-    public sealed partial class EggIncubatorAttributes : pb::IMessage<EggIncubatorAttributes>
-    {
-        /// <summary>Field number for the "incubator_type" field.</summary>
-        public const int IncubatorTypeFieldNumber = 1;
-
-        /// <summary>Field number for the "uses" field.</summary>
-        public const int UsesFieldNumber = 2;
-
-        /// <summary>Field number for the "distance_multiplier" field.</summary>
-        public const int DistanceMultiplierFieldNumber = 3;
-
-        private static readonly pb::MessageParser<EggIncubatorAttributes> _parser =
-            new pb::MessageParser<EggIncubatorAttributes>(() => new EggIncubatorAttributes());
-
-        private float distanceMultiplier_;
-        private global::PokemonGo.RocketAPI.GeneratedCode.EggIncubatorType incubatorType_ = 0;
-        private int uses_;
-
-        public EggIncubatorAttributes()
-        {
-            OnConstruction();
-        }
-
-        public EggIncubatorAttributes(EggIncubatorAttributes other) : this()
-        {
-            incubatorType_ = other.incubatorType_;
-            uses_ = other.uses_;
-            distanceMultiplier_ = other.distanceMultiplier_;
-        }
-
-        public static pb::MessageParser<EggIncubatorAttributes> Parser
-        {
-            get { return _parser; }
-        }
-
-        public static pbr::MessageDescriptor Descriptor
-        {
-            get { return global::PokemonGo.RocketAPI.GeneratedCode.PayloadsReflection.Descriptor.MessageTypes[85]; }
-        }
-
-        public global::PokemonGo.RocketAPI.GeneratedCode.EggIncubatorType IncubatorType
-        {
-            get { return incubatorType_; }
-            set { incubatorType_ = value; }
-        }
-
-        public int Uses
-        {
-            get { return uses_; }
-            set { uses_ = value; }
-        }
-
-        public float DistanceMultiplier
-        {
-            get { return distanceMultiplier_; }
-            set { distanceMultiplier_ = value; }
-        }
-
-        pbr::MessageDescriptor pb::IMessage.Descriptor
-        {
-            get { return Descriptor; }
-        }
-
-        public EggIncubatorAttributes Clone()
-        {
-            return new EggIncubatorAttributes(this);
-        }
-
-        public bool Equals(EggIncubatorAttributes other)
-        {
-            if (ReferenceEquals(other, null))
-            {
-                return false;
-            }
-            if (ReferenceEquals(other, this))
-            {
-                return true;
-            }
-            if (IncubatorType != other.IncubatorType) return false;
-            if (Uses != other.Uses) return false;
-            if (DistanceMultiplier != other.DistanceMultiplier) return false;
-            return true;
-        }
-
-        public void WriteTo(pb::CodedOutputStream output)
-        {
-            if (IncubatorType != 0)
-            {
-                output.WriteRawTag(8);
-                output.WriteEnum((int)IncubatorType);
-            }
-            if (Uses != 0)
-            {
-                output.WriteRawTag(16);
-                output.WriteInt32(Uses);
-            }
-            if (DistanceMultiplier != 0F)
-            {
-                output.WriteRawTag(29);
-                output.WriteFloat(DistanceMultiplier);
-            }
-        }
-
-        public int CalculateSize()
-        {
-            var size = 0;
-            if (IncubatorType != 0)
-            {
-                size += 1 + pb::CodedOutputStream.ComputeEnumSize((int)IncubatorType);
-            }
-            if (Uses != 0)
-            {
-                size += 1 + pb::CodedOutputStream.ComputeInt32Size(Uses);
-            }
-            if (DistanceMultiplier != 0F)
-            {
-                size += 1 + 4;
-            }
-            return size;
-        }
-
-        public void MergeFrom(EggIncubatorAttributes other)
-        {
-            if (other == null)
-            {
-                return;
-            }
-            if (other.IncubatorType != 0)
-            {
-                IncubatorType = other.IncubatorType;
-            }
-            if (other.Uses != 0)
-            {
-                Uses = other.Uses;
-            }
-            if (other.DistanceMultiplier != 0F)
-            {
-                DistanceMultiplier = other.DistanceMultiplier;
-            }
-        }
-
-        public void MergeFrom(pb::CodedInputStream input)
-        {
-            uint tag;
-            while ((tag = input.ReadTag()) != 0)
-            {
-                switch (tag)
-                {
-                    default:
-                        input.SkipLastField();
-                        break;
-                    case 8:
-                        {
-                            incubatorType_ = (global::PokemonGo.RocketAPI.GeneratedCode.EggIncubatorType)input.ReadEnum();
-                            break;
-                        }
-                    case 16:
-                        {
-                            Uses = input.ReadInt32();
-                            break;
-                        }
-                    case 29:
-                        {
-                            DistanceMultiplier = input.ReadFloat();
-                            break;
-                        }
-                }
-            }
-        }
-
-        public override bool Equals(object other)
-        {
-            return Equals(other as EggIncubatorAttributes);
-        }
-
-        public override int GetHashCode()
-        {
-            var hash = 1;
-            if (IncubatorType != 0) hash ^= IncubatorType.GetHashCode();
-            if (Uses != 0) hash ^= Uses.GetHashCode();
-            if (DistanceMultiplier != 0F) hash ^= DistanceMultiplier.GetHashCode();
-            return hash;
-        }
-
-        partial void OnConstruction();
-
-        public override string ToString()
-        {
-            return pb::JsonFormatter.ToDiagnosticString(this);
-        }
-    }
-
-    [global::System.Diagnostics.DebuggerNonUserCodeAttribute()]
-    public sealed partial class ExperienceBoostAttributes : pb::IMessage<ExperienceBoostAttributes>
-    {
-        /// <summary>Field number for the "xp_multiplier" field.</summary>
-        public const int XpMultiplierFieldNumber = 1;
-
-        /// <summary>Field number for the "boost_duration_ms" field.</summary>
-        public const int BoostDurationMsFieldNumber = 2;
-
-        private static readonly pb::MessageParser<ExperienceBoostAttributes> _parser =
-            new pb::MessageParser<ExperienceBoostAttributes>(() => new ExperienceBoostAttributes());
-
-        private int boostDurationMs_;
-        private float xpMultiplier_;
-
-        public ExperienceBoostAttributes()
-        {
-            OnConstruction();
-        }
-
-        public ExperienceBoostAttributes(ExperienceBoostAttributes other) : this()
-        {
-            xpMultiplier_ = other.xpMultiplier_;
-            boostDurationMs_ = other.boostDurationMs_;
-        }
-
-        public static pb::MessageParser<ExperienceBoostAttributes> Parser
-        {
-            get { return _parser; }
-        }
-
-        public static pbr::MessageDescriptor Descriptor
-        {
-            get { return global::PokemonGo.RocketAPI.GeneratedCode.PayloadsReflection.Descriptor.MessageTypes[86]; }
-        }
-
-        public float XpMultiplier
-        {
-            get { return xpMultiplier_; }
-            set { xpMultiplier_ = value; }
-        }
-
-        public int BoostDurationMs
-        {
-            get { return boostDurationMs_; }
-            set { boostDurationMs_ = value; }
-        }
-
-        pbr::MessageDescriptor pb::IMessage.Descriptor
-        {
-            get { return Descriptor; }
-        }
-
-        public ExperienceBoostAttributes Clone()
-        {
-            return new ExperienceBoostAttributes(this);
-        }
-
-        public bool Equals(ExperienceBoostAttributes other)
-        {
-            if (ReferenceEquals(other, null))
-            {
-                return false;
-            }
-            if (ReferenceEquals(other, this))
-            {
-                return true;
-            }
-            if (XpMultiplier != other.XpMultiplier) return false;
-            if (BoostDurationMs != other.BoostDurationMs) return false;
-            return true;
-        }
-
-        public void WriteTo(pb::CodedOutputStream output)
-        {
-            if (XpMultiplier != 0F)
-            {
-                output.WriteRawTag(13);
-                output.WriteFloat(XpMultiplier);
-            }
-            if (BoostDurationMs != 0)
-            {
-                output.WriteRawTag(16);
-                output.WriteInt32(BoostDurationMs);
-            }
-        }
-
-        public int CalculateSize()
-        {
-            var size = 0;
-            if (XpMultiplier != 0F)
-            {
-                size += 1 + 4;
-            }
-            if (BoostDurationMs != 0)
-            {
-                size += 1 + pb::CodedOutputStream.ComputeInt32Size(BoostDurationMs);
-            }
-            return size;
-        }
-
-        public void MergeFrom(ExperienceBoostAttributes other)
-        {
-            if (other == null)
-            {
-                return;
-            }
-            if (other.XpMultiplier != 0F)
-            {
-                XpMultiplier = other.XpMultiplier;
-            }
-            if (other.BoostDurationMs != 0)
-            {
-                BoostDurationMs = other.BoostDurationMs;
-            }
-        }
-
-        public void MergeFrom(pb::CodedInputStream input)
-        {
-            uint tag;
-            while ((tag = input.ReadTag()) != 0)
-            {
-                switch (tag)
-                {
-                    default:
-                        input.SkipLastField();
-                        break;
-                    case 13:
-                        {
-                            XpMultiplier = input.ReadFloat();
-                            break;
-                        }
-                    case 16:
-                        {
-                            BoostDurationMs = input.ReadInt32();
-                            break;
-                        }
-                }
-            }
-        }
-
-        public override bool Equals(object other)
-        {
-            return Equals(other as ExperienceBoostAttributes);
-        }
-
-        public override int GetHashCode()
-        {
-            var hash = 1;
-            if (XpMultiplier != 0F) hash ^= XpMultiplier.GetHashCode();
-            if (BoostDurationMs != 0) hash ^= BoostDurationMs.GetHashCode();
-            return hash;
-        }
-
-        partial void OnConstruction();
-
-        public override string ToString()
-        {
-            return pb::JsonFormatter.ToDiagnosticString(this);
-        }
-    }
-
-    [global::System.Diagnostics.DebuggerNonUserCodeAttribute()]
-    public sealed partial class FoodAttributes : pb::IMessage<FoodAttributes>
-    {
-        /// <summary>Field number for the "item_effect" field.</summary>
-        public const int ItemEffectFieldNumber = 1;
-
-        /// <summary>Field number for the "item_effect_percent" field.</summary>
-        public const int ItemEffectPercentFieldNumber = 2;
-
-        /// <summary>Field number for the "growth_percent" field.</summary>
-        public const int GrowthPercentFieldNumber = 3;
-
-        private static readonly pb::MessageParser<FoodAttributes> _parser =
-            new pb::MessageParser<FoodAttributes>(() => new FoodAttributes());
-
-        private static readonly pb::FieldCodec<global::PokemonGo.RocketAPI.GeneratedCode.ItemEffect>
-            _repeated_itemEffect_codec
-                = pb::FieldCodec.ForEnum(10, x => (int)x, x => (global::PokemonGo.RocketAPI.GeneratedCode.ItemEffect)x);
-
-        private static readonly pb::FieldCodec<float> _repeated_itemEffectPercent_codec
-            = pb::FieldCodec.ForFloat(18);
-
-        private readonly pbc::RepeatedField<global::PokemonGo.RocketAPI.GeneratedCode.ItemEffect> itemEffect_ =
-            new pbc::RepeatedField<global::PokemonGo.RocketAPI.GeneratedCode.ItemEffect>();
-
-        private readonly pbc::RepeatedField<float> itemEffectPercent_ = new pbc::RepeatedField<float>();
-        private float growthPercent_;
-
-        public FoodAttributes()
-        {
-            OnConstruction();
-        }
-
-        public FoodAttributes(FoodAttributes other) : this()
-        {
-            itemEffect_ = other.itemEffect_.Clone();
-            itemEffectPercent_ = other.itemEffectPercent_.Clone();
-            growthPercent_ = other.growthPercent_;
-        }
-
-        public static pb::MessageParser<FoodAttributes> Parser
-        {
-            get { return _parser; }
-        }
-
-        public static pbr::MessageDescriptor Descriptor
-        {
-            get { return global::PokemonGo.RocketAPI.GeneratedCode.PayloadsReflection.Descriptor.MessageTypes[87]; }
-        }
-
-        public pbc::RepeatedField<global::PokemonGo.RocketAPI.GeneratedCode.ItemEffect> ItemEffect
-        {
-            get { return itemEffect_; }
-        }
-
-        public pbc::RepeatedField<float> ItemEffectPercent
-        {
-            get { return itemEffectPercent_; }
-        }
-
-        public float GrowthPercent
-        {
-            get { return growthPercent_; }
-            set { growthPercent_ = value; }
-        }
-
-        pbr::MessageDescriptor pb::IMessage.Descriptor
-        {
-            get { return Descriptor; }
-        }
-
-        public FoodAttributes Clone()
-        {
-            return new FoodAttributes(this);
-        }
-
-        public bool Equals(FoodAttributes other)
-        {
-            if (ReferenceEquals(other, null))
-            {
-                return false;
-            }
-            if (ReferenceEquals(other, this))
-            {
-                return true;
-            }
-            if (!itemEffect_.Equals(other.itemEffect_)) return false;
-            if (!itemEffectPercent_.Equals(other.itemEffectPercent_)) return false;
-            if (GrowthPercent != other.GrowthPercent) return false;
-            return true;
-        }
-
-        public void WriteTo(pb::CodedOutputStream output)
-        {
-            itemEffect_.WriteTo(output, _repeated_itemEffect_codec);
-            itemEffectPercent_.WriteTo(output, _repeated_itemEffectPercent_codec);
-            if (GrowthPercent != 0F)
-            {
-                output.WriteRawTag(29);
-                output.WriteFloat(GrowthPercent);
-            }
-        }
-
-        public int CalculateSize()
-        {
-            var size = 0;
-            size += itemEffect_.CalculateSize(_repeated_itemEffect_codec);
-            size += itemEffectPercent_.CalculateSize(_repeated_itemEffectPercent_codec);
-            if (GrowthPercent != 0F)
-            {
-                size += 1 + 4;
-            }
-            return size;
-        }
-
-        public void MergeFrom(FoodAttributes other)
-        {
-            if (other == null)
-            {
-                return;
-            }
-            itemEffect_.Add(other.itemEffect_);
-            itemEffectPercent_.Add(other.itemEffectPercent_);
-            if (other.GrowthPercent != 0F)
-            {
-                GrowthPercent = other.GrowthPercent;
-            }
-        }
-
-        public void MergeFrom(pb::CodedInputStream input)
-        {
-            uint tag;
-            while ((tag = input.ReadTag()) != 0)
-            {
-                switch (tag)
-                {
-                    default:
-                        input.SkipLastField();
-                        break;
-                    case 10:
-                    case 8:
-                        {
-                            itemEffect_.AddEntriesFrom(input, _repeated_itemEffect_codec);
-                            break;
-                        }
-                    case 18:
-                    case 21:
-                        {
-                            itemEffectPercent_.AddEntriesFrom(input, _repeated_itemEffectPercent_codec);
-                            break;
-                        }
-                    case 29:
-                        {
-                            GrowthPercent = input.ReadFloat();
-                            break;
-                        }
-                }
-            }
-        }
-
-        public override bool Equals(object other)
-        {
-            return Equals(other as FoodAttributes);
-        }
-
-        public override int GetHashCode()
-        {
-            var hash = 1;
-            hash ^= itemEffect_.GetHashCode();
-            hash ^= itemEffectPercent_.GetHashCode();
-            if (GrowthPercent != 0F) hash ^= GrowthPercent.GetHashCode();
-            return hash;
-        }
-
-        partial void OnConstruction();
-
-        public override string ToString()
-        {
-            return pb::JsonFormatter.ToDiagnosticString(this);
-        }
-    }
-
-    [global::System.Diagnostics.DebuggerNonUserCodeAttribute()]
-    public sealed partial class FortModifierAttributes : pb::IMessage<FortModifierAttributes>
-    {
-        /// <summary>Field number for the "modifier_lifetime_seconds" field.</summary>
-        public const int ModifierLifetimeSecondsFieldNumber = 1;
-
-        /// <summary>Field number for the "troy_disk_num_pokemon_spawned" field.</summary>
-        public const int TroyDiskNumPokemonSpawnedFieldNumber = 2;
-
-        private static readonly pb::MessageParser<FortModifierAttributes> _parser =
-            new pb::MessageParser<FortModifierAttributes>(() => new FortModifierAttributes());
-
-        private int modifierLifetimeSeconds_;
-        private int troyDiskNumPokemonSpawned_;
-
-        public FortModifierAttributes()
-        {
-            OnConstruction();
-        }
-
-        public FortModifierAttributes(FortModifierAttributes other) : this()
-        {
-            modifierLifetimeSeconds_ = other.modifierLifetimeSeconds_;
-            troyDiskNumPokemonSpawned_ = other.troyDiskNumPokemonSpawned_;
-        }
-
-        public static pb::MessageParser<FortModifierAttributes> Parser
-        {
-            get { return _parser; }
-        }
-
-        public static pbr::MessageDescriptor Descriptor
-        {
-            get { return global::PokemonGo.RocketAPI.GeneratedCode.PayloadsReflection.Descriptor.MessageTypes[88]; }
-        }
-
-        public int ModifierLifetimeSeconds
-        {
-            get { return modifierLifetimeSeconds_; }
-            set { modifierLifetimeSeconds_ = value; }
-        }
-
-        public int TroyDiskNumPokemonSpawned
-        {
-            get { return troyDiskNumPokemonSpawned_; }
-            set { troyDiskNumPokemonSpawned_ = value; }
-        }
-
-        pbr::MessageDescriptor pb::IMessage.Descriptor
-        {
-            get { return Descriptor; }
-        }
-
-        public FortModifierAttributes Clone()
-        {
-            return new FortModifierAttributes(this);
-        }
-
-        public bool Equals(FortModifierAttributes other)
-        {
-            if (ReferenceEquals(other, null))
-            {
-                return false;
-            }
-            if (ReferenceEquals(other, this))
-            {
-                return true;
-            }
-            if (ModifierLifetimeSeconds != other.ModifierLifetimeSeconds) return false;
-            if (TroyDiskNumPokemonSpawned != other.TroyDiskNumPokemonSpawned) return false;
-            return true;
-        }
-
-        public void WriteTo(pb::CodedOutputStream output)
-        {
-            if (ModifierLifetimeSeconds != 0)
-            {
-                output.WriteRawTag(8);
-                output.WriteInt32(ModifierLifetimeSeconds);
-            }
-            if (TroyDiskNumPokemonSpawned != 0)
-            {
-                output.WriteRawTag(16);
-                output.WriteInt32(TroyDiskNumPokemonSpawned);
-            }
-        }
-
-        public int CalculateSize()
-        {
-            var size = 0;
-            if (ModifierLifetimeSeconds != 0)
-            {
-                size += 1 + pb::CodedOutputStream.ComputeInt32Size(ModifierLifetimeSeconds);
-            }
-            if (TroyDiskNumPokemonSpawned != 0)
-            {
-                size += 1 + pb::CodedOutputStream.ComputeInt32Size(TroyDiskNumPokemonSpawned);
-            }
-            return size;
-        }
-
-        public void MergeFrom(FortModifierAttributes other)
-        {
-            if (other == null)
-            {
-                return;
-            }
-            if (other.ModifierLifetimeSeconds != 0)
-            {
-                ModifierLifetimeSeconds = other.ModifierLifetimeSeconds;
-            }
-            if (other.TroyDiskNumPokemonSpawned != 0)
-            {
-                TroyDiskNumPokemonSpawned = other.TroyDiskNumPokemonSpawned;
-            }
-        }
-
-        public void MergeFrom(pb::CodedInputStream input)
-        {
-            uint tag;
-            while ((tag = input.ReadTag()) != 0)
-            {
-                switch (tag)
-                {
-                    default:
-                        input.SkipLastField();
-                        break;
-                    case 8:
-                        {
-                            ModifierLifetimeSeconds = input.ReadInt32();
-                            break;
-                        }
-                    case 16:
-                        {
-                            TroyDiskNumPokemonSpawned = input.ReadInt32();
-                            break;
-                        }
-                }
-            }
-        }
-
-        public override bool Equals(object other)
-        {
-            return Equals(other as FortModifierAttributes);
-        }
-
-        public override int GetHashCode()
-        {
-            var hash = 1;
-            if (ModifierLifetimeSeconds != 0) hash ^= ModifierLifetimeSeconds.GetHashCode();
-            if (TroyDiskNumPokemonSpawned != 0) hash ^= TroyDiskNumPokemonSpawned.GetHashCode();
-            return hash;
-        }
-
-        partial void OnConstruction();
-
-        public override string ToString()
-        {
-            return pb::JsonFormatter.ToDiagnosticString(this);
-        }
-    }
-
-    [global::System.Diagnostics.DebuggerNonUserCodeAttribute()]
-    public sealed partial class IncenseAttributes : pb::IMessage<IncenseAttributes>
-    {
-        /// <summary>Field number for the "incense_lifetime_seconds" field.</summary>
-        public const int IncenseLifetimeSecondsFieldNumber = 1;
-
-        /// <summary>Field number for the "pokemon_type" field.</summary>
-        public const int PokemonTypeFieldNumber = 2;
-
-        /// <summary>Field number for the "pokemon_incense_type_probability" field.</summary>
-        public const int PokemonIncenseTypeProbabilityFieldNumber = 3;
-
-        /// <summary>Field number for the "standing_time_between_encounters_seconds" field.</summary>
-        public const int StandingTimeBetweenEncountersSecondsFieldNumber = 4;
-
-        /// <summary>Field number for the "moving_time_between_encounter_seconds" field.</summary>
-        public const int MovingTimeBetweenEncounterSecondsFieldNumber = 5;
-
-        /// <summary>Field number for the "distance_required_for_shorter_interval_meters" field.</summary>
-        public const int DistanceRequiredForShorterIntervalMetersFieldNumber = 6;
-
-        /// <summary>Field number for the "pokemon_attracted_length_sec" field.</summary>
-        public const int PokemonAttractedLengthSecFieldNumber = 7;
-
-        private static readonly pb::MessageParser<IncenseAttributes> _parser =
-            new pb::MessageParser<IncenseAttributes>(() => new IncenseAttributes());
-
-        private static readonly pb::FieldCodec<global::PokemonGo.RocketAPI.GeneratedCode.PokemonType>
-            _repeated_pokemonType_codec
-                = pb::FieldCodec.ForEnum(18, x => (int)x,
-                    x => (global::PokemonGo.RocketAPI.GeneratedCode.PokemonType)x);
-
-        private readonly pbc::RepeatedField<global::PokemonGo.RocketAPI.GeneratedCode.PokemonType> pokemonType_ =
-            new pbc::RepeatedField<global::PokemonGo.RocketAPI.GeneratedCode.PokemonType>();
-
-        private int distanceRequiredForShorterIntervalMeters_;
-        private int incenseLifetimeSeconds_;
-        private int movingTimeBetweenEncounterSeconds_;
-        private int pokemonAttractedLengthSec_;
-        private float pokemonIncenseTypeProbability_;
-        private int standingTimeBetweenEncountersSeconds_;
-
-        public IncenseAttributes()
-        {
-            OnConstruction();
-        }
-
-        public IncenseAttributes(IncenseAttributes other) : this()
-        {
-            incenseLifetimeSeconds_ = other.incenseLifetimeSeconds_;
-            pokemonType_ = other.pokemonType_.Clone();
-            pokemonIncenseTypeProbability_ = other.pokemonIncenseTypeProbability_;
-            standingTimeBetweenEncountersSeconds_ = other.standingTimeBetweenEncountersSeconds_;
-            movingTimeBetweenEncounterSeconds_ = other.movingTimeBetweenEncounterSeconds_;
-            distanceRequiredForShorterIntervalMeters_ = other.distanceRequiredForShorterIntervalMeters_;
-            pokemonAttractedLengthSec_ = other.pokemonAttractedLengthSec_;
-        }
-
-        public static pb::MessageParser<IncenseAttributes> Parser
-        {
-            get { return _parser; }
-        }
-
-        public static pbr::MessageDescriptor Descriptor
-        {
-            get { return global::PokemonGo.RocketAPI.GeneratedCode.PayloadsReflection.Descriptor.MessageTypes[89]; }
-        }
-
-        public int IncenseLifetimeSeconds
-        {
-            get { return incenseLifetimeSeconds_; }
-            set { incenseLifetimeSeconds_ = value; }
-        }
-
-        public pbc::RepeatedField<global::PokemonGo.RocketAPI.GeneratedCode.PokemonType> PokemonType
-        {
-            get { return pokemonType_; }
-        }
-
-        public float PokemonIncenseTypeProbability
-        {
-            get { return pokemonIncenseTypeProbability_; }
-            set { pokemonIncenseTypeProbability_ = value; }
-        }
-
-        public int StandingTimeBetweenEncountersSeconds
-        {
-            get { return standingTimeBetweenEncountersSeconds_; }
-            set { standingTimeBetweenEncountersSeconds_ = value; }
-        }
-
-        public int MovingTimeBetweenEncounterSeconds
-        {
-            get { return movingTimeBetweenEncounterSeconds_; }
-            set { movingTimeBetweenEncounterSeconds_ = value; }
-        }
-
-        public int DistanceRequiredForShorterIntervalMeters
-        {
-            get { return distanceRequiredForShorterIntervalMeters_; }
-            set { distanceRequiredForShorterIntervalMeters_ = value; }
-        }
-
-        public int PokemonAttractedLengthSec
-        {
-            get { return pokemonAttractedLengthSec_; }
-            set { pokemonAttractedLengthSec_ = value; }
-        }
-
-        pbr::MessageDescriptor pb::IMessage.Descriptor
-        {
-            get { return Descriptor; }
-        }
-
-        public IncenseAttributes Clone()
-        {
-            return new IncenseAttributes(this);
-        }
-
-        public bool Equals(IncenseAttributes other)
-        {
-            if (ReferenceEquals(other, null))
-            {
-                return false;
-            }
-            if (ReferenceEquals(other, this))
-            {
-                return true;
-            }
-            if (IncenseLifetimeSeconds != other.IncenseLifetimeSeconds) return false;
-            if (!pokemonType_.Equals(other.pokemonType_)) return false;
-            if (PokemonIncenseTypeProbability != other.PokemonIncenseTypeProbability) return false;
-            if (StandingTimeBetweenEncountersSeconds != other.StandingTimeBetweenEncountersSeconds) return false;
-            if (MovingTimeBetweenEncounterSeconds != other.MovingTimeBetweenEncounterSeconds) return false;
-            if (DistanceRequiredForShorterIntervalMeters != other.DistanceRequiredForShorterIntervalMeters)
-                return false;
-            if (PokemonAttractedLengthSec != other.PokemonAttractedLengthSec) return false;
-            return true;
-        }
-
-        public void WriteTo(pb::CodedOutputStream output)
-        {
-            if (IncenseLifetimeSeconds != 0)
-            {
-                output.WriteRawTag(8);
-                output.WriteInt32(IncenseLifetimeSeconds);
-            }
-            pokemonType_.WriteTo(output, _repeated_pokemonType_codec);
-            if (PokemonIncenseTypeProbability != 0F)
-            {
-                output.WriteRawTag(29);
-                output.WriteFloat(PokemonIncenseTypeProbability);
-            }
-            if (StandingTimeBetweenEncountersSeconds != 0)
-            {
-                output.WriteRawTag(32);
-                output.WriteInt32(StandingTimeBetweenEncountersSeconds);
-            }
-            if (MovingTimeBetweenEncounterSeconds != 0)
-            {
-                output.WriteRawTag(40);
-                output.WriteInt32(MovingTimeBetweenEncounterSeconds);
-            }
-            if (DistanceRequiredForShorterIntervalMeters != 0)
-            {
-                output.WriteRawTag(48);
-                output.WriteInt32(DistanceRequiredForShorterIntervalMeters);
-            }
-            if (PokemonAttractedLengthSec != 0)
-            {
-                output.WriteRawTag(56);
-                output.WriteInt32(PokemonAttractedLengthSec);
-            }
-        }
-
-        public int CalculateSize()
-        {
-            var size = 0;
-            if (IncenseLifetimeSeconds != 0)
-            {
-                size += 1 + pb::CodedOutputStream.ComputeInt32Size(IncenseLifetimeSeconds);
-            }
-            size += pokemonType_.CalculateSize(_repeated_pokemonType_codec);
-            if (PokemonIncenseTypeProbability != 0F)
-            {
-                size += 1 + 4;
-            }
-            if (StandingTimeBetweenEncountersSeconds != 0)
-            {
-                size += 1 + pb::CodedOutputStream.ComputeInt32Size(StandingTimeBetweenEncountersSeconds);
-            }
-            if (MovingTimeBetweenEncounterSeconds != 0)
-            {
-                size += 1 + pb::CodedOutputStream.ComputeInt32Size(MovingTimeBetweenEncounterSeconds);
-            }
-            if (DistanceRequiredForShorterIntervalMeters != 0)
-            {
-                size += 1 + pb::CodedOutputStream.ComputeInt32Size(DistanceRequiredForShorterIntervalMeters);
-            }
-            if (PokemonAttractedLengthSec != 0)
-            {
-                size += 1 + pb::CodedOutputStream.ComputeInt32Size(PokemonAttractedLengthSec);
-            }
-            return size;
-        }
-
-        public void MergeFrom(IncenseAttributes other)
-        {
-            if (other == null)
-            {
-                return;
-            }
-            if (other.IncenseLifetimeSeconds != 0)
-            {
-                IncenseLifetimeSeconds = other.IncenseLifetimeSeconds;
-            }
-            pokemonType_.Add(other.pokemonType_);
-            if (other.PokemonIncenseTypeProbability != 0F)
-            {
-                PokemonIncenseTypeProbability = other.PokemonIncenseTypeProbability;
-            }
-            if (other.StandingTimeBetweenEncountersSeconds != 0)
-            {
-                StandingTimeBetweenEncountersSeconds = other.StandingTimeBetweenEncountersSeconds;
-            }
-            if (other.MovingTimeBetweenEncounterSeconds != 0)
-            {
-                MovingTimeBetweenEncounterSeconds = other.MovingTimeBetweenEncounterSeconds;
-            }
-            if (other.DistanceRequiredForShorterIntervalMeters != 0)
-            {
-                DistanceRequiredForShorterIntervalMeters = other.DistanceRequiredForShorterIntervalMeters;
-            }
-            if (other.PokemonAttractedLengthSec != 0)
-            {
-                PokemonAttractedLengthSec = other.PokemonAttractedLengthSec;
-            }
-        }
-
-        public void MergeFrom(pb::CodedInputStream input)
-        {
-            uint tag;
-            while ((tag = input.ReadTag()) != 0)
-            {
-                switch (tag)
-                {
-                    default:
-                        input.SkipLastField();
-                        break;
-                    case 8:
-                        {
-                            IncenseLifetimeSeconds = input.ReadInt32();
-                            break;
-                        }
-                    case 18:
-                    case 16:
-                        {
-                            pokemonType_.AddEntriesFrom(input, _repeated_pokemonType_codec);
-                            break;
-                        }
-                    case 29:
-                        {
-                            PokemonIncenseTypeProbability = input.ReadFloat();
-                            break;
-                        }
-                    case 32:
-                        {
-                            StandingTimeBetweenEncountersSeconds = input.ReadInt32();
-                            break;
-                        }
-                    case 40:
-                        {
-                            MovingTimeBetweenEncounterSeconds = input.ReadInt32();
-                            break;
-                        }
-                    case 48:
-                        {
-                            DistanceRequiredForShorterIntervalMeters = input.ReadInt32();
-                            break;
-                        }
-                    case 56:
-                        {
-                            PokemonAttractedLengthSec = input.ReadInt32();
-                            break;
-                        }
-                }
-            }
-        }
-
-        public override bool Equals(object other)
-        {
-            return Equals(other as IncenseAttributes);
-        }
-
-        public override int GetHashCode()
-        {
-            var hash = 1;
-            if (IncenseLifetimeSeconds != 0) hash ^= IncenseLifetimeSeconds.GetHashCode();
-            hash ^= pokemonType_.GetHashCode();
-            if (PokemonIncenseTypeProbability != 0F) hash ^= PokemonIncenseTypeProbability.GetHashCode();
-            if (StandingTimeBetweenEncountersSeconds != 0) hash ^= StandingTimeBetweenEncountersSeconds.GetHashCode();
-            if (MovingTimeBetweenEncounterSeconds != 0) hash ^= MovingTimeBetweenEncounterSeconds.GetHashCode();
-            if (DistanceRequiredForShorterIntervalMeters != 0)
-                hash ^= DistanceRequiredForShorterIntervalMeters.GetHashCode();
-            if (PokemonAttractedLengthSec != 0) hash ^= PokemonAttractedLengthSec.GetHashCode();
-            return hash;
-        }
-
-        partial void OnConstruction();
-
-        public override string ToString()
-        {
-            return pb::JsonFormatter.ToDiagnosticString(this);
-        }
-    }
-
-    [global::System.Diagnostics.DebuggerNonUserCodeAttribute()]
-    public sealed partial class InventoryUpgradeAttributes : pb::IMessage<InventoryUpgradeAttributes>
-    {
-        /// <summary>Field number for the "additional_storage" field.</summary>
-        public const int AdditionalStorageFieldNumber = 1;
-
-        /// <summary>Field number for the "upgrade_type" field.</summary>
-        public const int UpgradeTypeFieldNumber = 2;
-
-        private static readonly pb::MessageParser<InventoryUpgradeAttributes> _parser =
-            new pb::MessageParser<InventoryUpgradeAttributes>(() => new InventoryUpgradeAttributes());
-
-        private int additionalStorage_;
-        private global::PokemonGo.RocketAPI.GeneratedCode.InventoryUpgradeType upgradeType_ = 0;
-
-        public InventoryUpgradeAttributes()
-        {
-            OnConstruction();
-        }
-
-        public InventoryUpgradeAttributes(InventoryUpgradeAttributes other) : this()
-        {
-            additionalStorage_ = other.additionalStorage_;
-            upgradeType_ = other.upgradeType_;
-        }
-
-        public static pb::MessageParser<InventoryUpgradeAttributes> Parser
-        {
-            get { return _parser; }
-        }
-
-        public static pbr::MessageDescriptor Descriptor
-        {
-            get { return global::PokemonGo.RocketAPI.GeneratedCode.PayloadsReflection.Descriptor.MessageTypes[90]; }
-        }
-
-        public int AdditionalStorage
-        {
-            get { return additionalStorage_; }
-            set { additionalStorage_ = value; }
-        }
-
-        public global::PokemonGo.RocketAPI.GeneratedCode.InventoryUpgradeType UpgradeType
-        {
-            get { return upgradeType_; }
-            set { upgradeType_ = value; }
-        }
-
-        pbr::MessageDescriptor pb::IMessage.Descriptor
-        {
-            get { return Descriptor; }
-        }
-
-        public InventoryUpgradeAttributes Clone()
-        {
-            return new InventoryUpgradeAttributes(this);
-        }
-
-        public bool Equals(InventoryUpgradeAttributes other)
-        {
-            if (ReferenceEquals(other, null))
-            {
-                return false;
-            }
-            if (ReferenceEquals(other, this))
-            {
-                return true;
-            }
-            if (AdditionalStorage != other.AdditionalStorage) return false;
-            if (UpgradeType != other.UpgradeType) return false;
-            return true;
-        }
-
-        public void WriteTo(pb::CodedOutputStream output)
-        {
-            if (AdditionalStorage != 0)
-            {
-                output.WriteRawTag(8);
-                output.WriteInt32(AdditionalStorage);
-            }
-            if (UpgradeType != 0)
-            {
-                output.WriteRawTag(16);
-                output.WriteEnum((int)UpgradeType);
-            }
-        }
-
-        public int CalculateSize()
-        {
-            var size = 0;
-            if (AdditionalStorage != 0)
-            {
-                size += 1 + pb::CodedOutputStream.ComputeInt32Size(AdditionalStorage);
-            }
-            if (UpgradeType != 0)
-            {
-                size += 1 + pb::CodedOutputStream.ComputeEnumSize((int)UpgradeType);
-            }
-            return size;
-        }
-
-        public void MergeFrom(InventoryUpgradeAttributes other)
-        {
-            if (other == null)
-            {
-                return;
-            }
-            if (other.AdditionalStorage != 0)
-            {
-                AdditionalStorage = other.AdditionalStorage;
-            }
-            if (other.UpgradeType != 0)
-            {
-                UpgradeType = other.UpgradeType;
-            }
-        }
-
-        public void MergeFrom(pb::CodedInputStream input)
-        {
-            uint tag;
-            while ((tag = input.ReadTag()) != 0)
-            {
-                switch (tag)
-                {
-                    default:
-                        input.SkipLastField();
-                        break;
-                    case 8:
-                        {
-                            AdditionalStorage = input.ReadInt32();
-                            break;
-                        }
-                    case 16:
-                        {
-                            upgradeType_ = (global::PokemonGo.RocketAPI.GeneratedCode.InventoryUpgradeType)input.ReadEnum();
-                            break;
-                        }
-                }
-            }
-        }
-
-        public override bool Equals(object other)
-        {
-            return Equals(other as InventoryUpgradeAttributes);
-        }
-
-        public override int GetHashCode()
-        {
-            var hash = 1;
-            if (AdditionalStorage != 0) hash ^= AdditionalStorage.GetHashCode();
-            if (UpgradeType != 0) hash ^= UpgradeType.GetHashCode();
-            return hash;
-        }
-
-        partial void OnConstruction();
-
-        public override string ToString()
-        {
-            return pb::JsonFormatter.ToDiagnosticString(this);
-        }
-    }
-
-    [global::System.Diagnostics.DebuggerNonUserCodeAttribute()]
-    public sealed partial class PokeballAttributes : pb::IMessage<PokeballAttributes>
-    {
-        /// <summary>Field number for the "item_effect" field.</summary>
-        public const int ItemEffectFieldNumber = 1;
-
-        /// <summary>Field number for the "capture_multi" field.</summary>
-        public const int CaptureMultiFieldNumber = 2;
-
-        /// <summary>Field number for the "capture_multi_effect" field.</summary>
-        public const int CaptureMultiEffectFieldNumber = 3;
-
-        /// <summary>Field number for the "item_effect_mod" field.</summary>
-        public const int ItemEffectModFieldNumber = 4;
-
-        private static readonly pb::MessageParser<PokeballAttributes> _parser =
-            new pb::MessageParser<PokeballAttributes>(() => new PokeballAttributes());
-
-        private float captureMulti_;
-        private float captureMultiEffect_;
-        private global::PokemonGo.RocketAPI.GeneratedCode.ItemEffect itemEffect_ = 0;
-        private float itemEffectMod_;
-
-        public PokeballAttributes()
-        {
-            OnConstruction();
-        }
-
-        public PokeballAttributes(PokeballAttributes other) : this()
-        {
-            itemEffect_ = other.itemEffect_;
-            captureMulti_ = other.captureMulti_;
-            captureMultiEffect_ = other.captureMultiEffect_;
-            itemEffectMod_ = other.itemEffectMod_;
-        }
-
-        public static pb::MessageParser<PokeballAttributes> Parser
-        {
-            get { return _parser; }
-        }
-
-        public static pbr::MessageDescriptor Descriptor
-        {
-            get { return global::PokemonGo.RocketAPI.GeneratedCode.PayloadsReflection.Descriptor.MessageTypes[91]; }
-        }
-
-        public global::PokemonGo.RocketAPI.GeneratedCode.ItemEffect ItemEffect
-        {
-            get { return itemEffect_; }
-            set { itemEffect_ = value; }
-        }
-
-        public float CaptureMulti
-        {
-            get { return captureMulti_; }
-            set { captureMulti_ = value; }
-        }
-
-        public float CaptureMultiEffect
-        {
-            get { return captureMultiEffect_; }
-            set { captureMultiEffect_ = value; }
-        }
-
-        public float ItemEffectMod
-        {
-            get { return itemEffectMod_; }
-            set { itemEffectMod_ = value; }
-        }
-
-        pbr::MessageDescriptor pb::IMessage.Descriptor
-        {
-            get { return Descriptor; }
-        }
-
-        public PokeballAttributes Clone()
-        {
-            return new PokeballAttributes(this);
-        }
-
-        public bool Equals(PokeballAttributes other)
-        {
-            if (ReferenceEquals(other, null))
-            {
-                return false;
-            }
-            if (ReferenceEquals(other, this))
-            {
-                return true;
-            }
-            if (ItemEffect != other.ItemEffect) return false;
-            if (CaptureMulti != other.CaptureMulti) return false;
-            if (CaptureMultiEffect != other.CaptureMultiEffect) return false;
-            if (ItemEffectMod != other.ItemEffectMod) return false;
-            return true;
-        }
-
-        public void WriteTo(pb::CodedOutputStream output)
-        {
-            if (ItemEffect != 0)
-            {
-                output.WriteRawTag(8);
-                output.WriteEnum((int)ItemEffect);
-            }
-            if (CaptureMulti != 0F)
-            {
-                output.WriteRawTag(21);
-                output.WriteFloat(CaptureMulti);
-            }
-            if (CaptureMultiEffect != 0F)
-            {
-                output.WriteRawTag(29);
-                output.WriteFloat(CaptureMultiEffect);
-            }
-            if (ItemEffectMod != 0F)
-            {
-                output.WriteRawTag(37);
-                output.WriteFloat(ItemEffectMod);
-            }
-        }
-
-        public int CalculateSize()
-        {
-            var size = 0;
-            if (ItemEffect != 0)
-            {
-                size += 1 + pb::CodedOutputStream.ComputeEnumSize((int)ItemEffect);
-            }
-            if (CaptureMulti != 0F)
-            {
-                size += 1 + 4;
-            }
-            if (CaptureMultiEffect != 0F)
-            {
-                size += 1 + 4;
-            }
-            if (ItemEffectMod != 0F)
-            {
-                size += 1 + 4;
-            }
-            return size;
-        }
-
-        public void MergeFrom(PokeballAttributes other)
-        {
-            if (other == null)
-            {
-                return;
-            }
-            if (other.ItemEffect != 0)
-            {
-                ItemEffect = other.ItemEffect;
-            }
-            if (other.CaptureMulti != 0F)
-            {
-                CaptureMulti = other.CaptureMulti;
-            }
-            if (other.CaptureMultiEffect != 0F)
-            {
-                CaptureMultiEffect = other.CaptureMultiEffect;
-            }
-            if (other.ItemEffectMod != 0F)
-            {
-                ItemEffectMod = other.ItemEffectMod;
-            }
-        }
-
-        public void MergeFrom(pb::CodedInputStream input)
-        {
-            uint tag;
-            while ((tag = input.ReadTag()) != 0)
-            {
-                switch (tag)
-                {
-                    default:
-                        input.SkipLastField();
-                        break;
-                    case 8:
-                        {
-                            itemEffect_ = (global::PokemonGo.RocketAPI.GeneratedCode.ItemEffect)input.ReadEnum();
-                            break;
-                        }
-                    case 21:
-                        {
-                            CaptureMulti = input.ReadFloat();
-                            break;
-                        }
-                    case 29:
-                        {
-                            CaptureMultiEffect = input.ReadFloat();
-                            break;
-                        }
-                    case 37:
-                        {
-                            ItemEffectMod = input.ReadFloat();
-                            break;
-                        }
-                }
-            }
-        }
-
-        public override bool Equals(object other)
-        {
-            return Equals(other as PokeballAttributes);
-        }
-
-        public override int GetHashCode()
-        {
-            var hash = 1;
-            if (ItemEffect != 0) hash ^= ItemEffect.GetHashCode();
-            if (CaptureMulti != 0F) hash ^= CaptureMulti.GetHashCode();
-            if (CaptureMultiEffect != 0F) hash ^= CaptureMultiEffect.GetHashCode();
-            if (ItemEffectMod != 0F) hash ^= ItemEffectMod.GetHashCode();
-            return hash;
-        }
-
-        partial void OnConstruction();
-
-        public override string ToString()
-        {
-            return pb::JsonFormatter.ToDiagnosticString(this);
-        }
-    }
-
-    [global::System.Diagnostics.DebuggerNonUserCodeAttribute()]
-    public sealed partial class PotionAttributes : pb::IMessage<PotionAttributes>
-    {
-        /// <summary>Field number for the "sta_percent" field.</summary>
-        public const int StaPercentFieldNumber = 1;
-
-        /// <summary>Field number for the "sta_amount" field.</summary>
-        public const int StaAmountFieldNumber = 2;
-
-        private static readonly pb::MessageParser<PotionAttributes> _parser =
-            new pb::MessageParser<PotionAttributes>(() => new PotionAttributes());
-
-        private int staAmount_;
-        private float staPercent_;
-
-        public PotionAttributes()
-        {
-            OnConstruction();
-        }
-
-        public PotionAttributes(PotionAttributes other) : this()
-        {
-            staPercent_ = other.staPercent_;
-            staAmount_ = other.staAmount_;
-        }
-
-        public static pb::MessageParser<PotionAttributes> Parser
-        {
-            get { return _parser; }
-        }
-
-        public static pbr::MessageDescriptor Descriptor
-        {
-            get { return global::PokemonGo.RocketAPI.GeneratedCode.PayloadsReflection.Descriptor.MessageTypes[92]; }
-        }
-
-        public float StaPercent
-        {
-            get { return staPercent_; }
-            set { staPercent_ = value; }
-        }
-
-        public int StaAmount
-        {
-            get { return staAmount_; }
-            set { staAmount_ = value; }
-        }
-
-        pbr::MessageDescriptor pb::IMessage.Descriptor
-        {
-            get { return Descriptor; }
-        }
-
-        public PotionAttributes Clone()
-        {
-            return new PotionAttributes(this);
-        }
-
-        public bool Equals(PotionAttributes other)
-        {
-            if (ReferenceEquals(other, null))
-            {
-                return false;
-            }
-            if (ReferenceEquals(other, this))
-            {
-                return true;
-            }
-            if (StaPercent != other.StaPercent) return false;
-            if (StaAmount != other.StaAmount) return false;
-            return true;
-        }
-
-        public void WriteTo(pb::CodedOutputStream output)
-        {
-            if (StaPercent != 0F)
-            {
-                output.WriteRawTag(13);
-                output.WriteFloat(StaPercent);
-            }
-            if (StaAmount != 0)
-            {
-                output.WriteRawTag(16);
-                output.WriteInt32(StaAmount);
-            }
-        }
-
-        public int CalculateSize()
-        {
-            var size = 0;
-            if (StaPercent != 0F)
-            {
-                size += 1 + 4;
-            }
-            if (StaAmount != 0)
-            {
-                size += 1 + pb::CodedOutputStream.ComputeInt32Size(StaAmount);
-            }
-            return size;
-        }
-
-        public void MergeFrom(PotionAttributes other)
-        {
-            if (other == null)
-            {
-                return;
-            }
-            if (other.StaPercent != 0F)
-            {
-                StaPercent = other.StaPercent;
-            }
-            if (other.StaAmount != 0)
-            {
-                StaAmount = other.StaAmount;
-            }
-        }
-
-        public void MergeFrom(pb::CodedInputStream input)
-        {
-            uint tag;
-            while ((tag = input.ReadTag()) != 0)
-            {
-                switch (tag)
-                {
-                    default:
-                        input.SkipLastField();
-                        break;
-                    case 13:
-                        {
-                            StaPercent = input.ReadFloat();
-                            break;
-                        }
-                    case 16:
-                        {
-                            StaAmount = input.ReadInt32();
-                            break;
-                        }
-                }
-            }
-        }
-
-        public override bool Equals(object other)
-        {
-            return Equals(other as PotionAttributes);
-        }
-
-        public override int GetHashCode()
-        {
-            var hash = 1;
-            if (StaPercent != 0F) hash ^= StaPercent.GetHashCode();
-            if (StaAmount != 0) hash ^= StaAmount.GetHashCode();
-            return hash;
-        }
-
-        partial void OnConstruction();
-
-        public override string ToString()
-        {
-            return pb::JsonFormatter.ToDiagnosticString(this);
-        }
-    }
-
-    [global::System.Diagnostics.DebuggerNonUserCodeAttribute()]
-    public sealed partial class ReviveAttributes : pb::IMessage<ReviveAttributes>
-    {
-        /// <summary>Field number for the "sta_percent" field.</summary>
-        public const int StaPercentFieldNumber = 1;
-
-        private static readonly pb::MessageParser<ReviveAttributes> _parser =
-            new pb::MessageParser<ReviveAttributes>(() => new ReviveAttributes());
-
-        private float staPercent_;
-
-        public ReviveAttributes()
-        {
-            OnConstruction();
-        }
-
-        public ReviveAttributes(ReviveAttributes other) : this()
-        {
-            staPercent_ = other.staPercent_;
-        }
-
-        public static pb::MessageParser<ReviveAttributes> Parser
-        {
-            get { return _parser; }
-        }
-
-        public static pbr::MessageDescriptor Descriptor
-        {
-            get { return global::PokemonGo.RocketAPI.GeneratedCode.PayloadsReflection.Descriptor.MessageTypes[93]; }
-        }
-
-        public float StaPercent
-        {
-            get { return staPercent_; }
-            set { staPercent_ = value; }
-        }
-
-        pbr::MessageDescriptor pb::IMessage.Descriptor
-        {
-            get { return Descriptor; }
-        }
-
-        public ReviveAttributes Clone()
-        {
-            return new ReviveAttributes(this);
-        }
-
-        public bool Equals(ReviveAttributes other)
-        {
-            if (ReferenceEquals(other, null))
-            {
-                return false;
-            }
-            if (ReferenceEquals(other, this))
-            {
-                return true;
-            }
-            if (StaPercent != other.StaPercent) return false;
-            return true;
-        }
-
-        public void WriteTo(pb::CodedOutputStream output)
-        {
-            if (StaPercent != 0F)
-            {
-                output.WriteRawTag(13);
-                output.WriteFloat(StaPercent);
-            }
-        }
-
-        public int CalculateSize()
-        {
-            var size = 0;
-            if (StaPercent != 0F)
-            {
-                size += 1 + 4;
-            }
-            return size;
-        }
-
-        public void MergeFrom(ReviveAttributes other)
-        {
-            if (other == null)
-            {
-                return;
-            }
-            if (other.StaPercent != 0F)
-            {
-                StaPercent = other.StaPercent;
-            }
-        }
-
-        public void MergeFrom(pb::CodedInputStream input)
-        {
-            uint tag;
-            while ((tag = input.ReadTag()) != 0)
-            {
-                switch (tag)
-                {
-                    default:
-                        input.SkipLastField();
-                        break;
-                    case 13:
-                        {
-                            StaPercent = input.ReadFloat();
-                            break;
-                        }
-                }
-            }
-        }
-
-        public override bool Equals(object other)
-        {
-            return Equals(other as ReviveAttributes);
-        }
-
-        public override int GetHashCode()
-        {
-            var hash = 1;
-            if (StaPercent != 0F) hash ^= StaPercent.GetHashCode();
-            return hash;
-        }
-
-        partial void OnConstruction();
-
-        public override string ToString()
-        {
-            return pb::JsonFormatter.ToDiagnosticString(this);
-        }
-    }
-
-    /// <summary>
-    ///     POKEMON TRANSFER
-    /// </summary>
-    [global::System.Diagnostics.DebuggerNonUserCodeAttribute()]
-    public sealed partial class TransferPokemon : pb::IMessage<TransferPokemon>
-    {
-        /// <summary>Field number for the "PokemonId" field.</summary>
-        public const int PokemonIdFieldNumber = 1;
-
-        private static readonly pb::MessageParser<TransferPokemon> _parser =
-            new pb::MessageParser<TransferPokemon>(() => new TransferPokemon());
-
-        private ulong pokemonId_;
-
-        public TransferPokemon()
-        {
-            OnConstruction();
-        }
-
-        public TransferPokemon(TransferPokemon other) : this()
-        {
-            pokemonId_ = other.pokemonId_;
-        }
-
-        public static pb::MessageParser<TransferPokemon> Parser
-        {
-            get { return _parser; }
-        }
-
-        public static pbr::MessageDescriptor Descriptor
-        {
-            get { return global::PokemonGo.RocketAPI.GeneratedCode.PayloadsReflection.Descriptor.MessageTypes[94]; }
-        }
-
-        public ulong PokemonId
-        {
-            get { return pokemonId_; }
-            set { pokemonId_ = value; }
-        }
-
-        pbr::MessageDescriptor pb::IMessage.Descriptor
-        {
-            get { return Descriptor; }
-        }
-
-        public TransferPokemon Clone()
-        {
-            return new TransferPokemon(this);
-        }
-
-        public bool Equals(TransferPokemon other)
-        {
-            if (ReferenceEquals(other, null))
-            {
-                return false;
-            }
-            if (ReferenceEquals(other, this))
-            {
-                return true;
-            }
-            if (PokemonId != other.PokemonId) return false;
-            return true;
-        }
-
-        public void WriteTo(pb::CodedOutputStream output)
-        {
-            if (PokemonId != 0UL)
-            {
-                output.WriteRawTag(9);
-                output.WriteFixed64(PokemonId);
-            }
-        }
-
-        public int CalculateSize()
-        {
-            var size = 0;
-            if (PokemonId != 0UL)
-            {
-                size += 1 + 8;
-            }
-            return size;
-        }
-
-        public void MergeFrom(TransferPokemon other)
-        {
-            if (other == null)
-            {
-                return;
-            }
-            if (other.PokemonId != 0UL)
-            {
-                PokemonId = other.PokemonId;
-            }
-        }
-
-        public void MergeFrom(pb::CodedInputStream input)
-        {
-            uint tag;
-            while ((tag = input.ReadTag()) != 0)
-            {
-                switch (tag)
-                {
-                    default:
-                        input.SkipLastField();
-                        break;
-                    case 9:
-                        {
-                            PokemonId = input.ReadFixed64();
-                            break;
-                        }
-                }
-            }
-        }
-
-        public override bool Equals(object other)
-        {
-            return Equals(other as TransferPokemon);
-        }
-
-        public override int GetHashCode()
-        {
-            var hash = 1;
-            if (PokemonId != 0UL) hash ^= PokemonId.GetHashCode();
-            return hash;
-        }
-
-        partial void OnConstruction();
-
-        public override string ToString()
-        {
-            return pb::JsonFormatter.ToDiagnosticString(this);
-        }
-    }
-
-    [global::System.Diagnostics.DebuggerNonUserCodeAttribute()]
-    public sealed partial class TransferPokemonOut : pb::IMessage<TransferPokemonOut>
-    {
-        /// <summary>Field number for the "Status" field.</summary>
-        public const int StatusFieldNumber = 1;
-
-        /// <summary>Field number for the "CandyAwarded" field.</summary>
-        public const int CandyAwardedFieldNumber = 2;
-
-        private static readonly pb::MessageParser<TransferPokemonOut> _parser =
-            new pb::MessageParser<TransferPokemonOut>(() => new TransferPokemonOut());
-
-        private int candyAwarded_;
-        private int status_;
-
-        public TransferPokemonOut()
-        {
-            OnConstruction();
-        }
-
-        public TransferPokemonOut(TransferPokemonOut other) : this()
-        {
-            status_ = other.status_;
-            candyAwarded_ = other.candyAwarded_;
-        }
-
-        public static pb::MessageParser<TransferPokemonOut> Parser
-        {
-            get { return _parser; }
-        }
-
-        public static pbr::MessageDescriptor Descriptor
-        {
-            get { return global::PokemonGo.RocketAPI.GeneratedCode.PayloadsReflection.Descriptor.MessageTypes[95]; }
-        }
-
-        public int Status
-        {
-            get { return status_; }
-            set { status_ = value; }
-        }
-
-        public int CandyAwarded
-        {
-            get { return candyAwarded_; }
-            set { candyAwarded_ = value; }
-        }
-
-        pbr::MessageDescriptor pb::IMessage.Descriptor
-        {
-            get { return Descriptor; }
-        }
-
-        public TransferPokemonOut Clone()
-        {
-            return new TransferPokemonOut(this);
-        }
-
-        public bool Equals(TransferPokemonOut other)
-        {
-            if (ReferenceEquals(other, null))
-            {
-                return false;
-            }
-            if (ReferenceEquals(other, this))
-            {
-                return true;
-            }
-            if (Status != other.Status) return false;
-            if (CandyAwarded != other.CandyAwarded) return false;
-            return true;
-        }
-
-        public void WriteTo(pb::CodedOutputStream output)
-        {
-            if (Status != 0)
-            {
-                output.WriteRawTag(8);
-                output.WriteInt32(Status);
-            }
-            if (CandyAwarded != 0)
-            {
-                output.WriteRawTag(16);
-                output.WriteInt32(CandyAwarded);
-            }
-        }
-
-        public int CalculateSize()
-        {
-            var size = 0;
-            if (Status != 0)
-            {
-                size += 1 + pb::CodedOutputStream.ComputeInt32Size(Status);
-            }
-            if (CandyAwarded != 0)
-            {
-                size += 1 + pb::CodedOutputStream.ComputeInt32Size(CandyAwarded);
-            }
-            return size;
-        }
-
-        public void MergeFrom(TransferPokemonOut other)
-        {
-            if (other == null)
-            {
-                return;
-            }
-            if (other.Status != 0)
-            {
-                Status = other.Status;
-            }
-            if (other.CandyAwarded != 0)
-            {
-                CandyAwarded = other.CandyAwarded;
-            }
-        }
-
-        public void MergeFrom(pb::CodedInputStream input)
-        {
-            uint tag;
-            while ((tag = input.ReadTag()) != 0)
-            {
-                switch (tag)
-                {
-                    default:
-                        input.SkipLastField();
-                        break;
-                    case 8:
-                        {
-                            Status = input.ReadInt32();
-                            break;
-                        }
-                    case 16:
-                        {
-                            CandyAwarded = input.ReadInt32();
-                            break;
-                        }
-                }
-            }
-        }
-
-        public override bool Equals(object other)
-        {
-            return Equals(other as TransferPokemonOut);
-        }
-
-        public override int GetHashCode()
-        {
-            var hash = 1;
-            if (Status != 0) hash ^= Status.GetHashCode();
-            if (CandyAwarded != 0) hash ^= CandyAwarded.GetHashCode();
-            return hash;
-        }
-
-        partial void OnConstruction();
-
-        public override string ToString()
-        {
-            return pb::JsonFormatter.ToDiagnosticString(this);
-        }
-    }
-
-    /// <summary>
-    ///     EVOLVE
-    /// </summary>
-    [global::System.Diagnostics.DebuggerNonUserCodeAttribute()]
-    public sealed partial class EvolvePokemon : pb::IMessage<EvolvePokemon>
-    {
-        /// <summary>Field number for the "PokemonId" field.</summary>
-        public const int PokemonIdFieldNumber = 1;
-
-        private static readonly pb::MessageParser<EvolvePokemon> _parser =
-            new pb::MessageParser<EvolvePokemon>(() => new EvolvePokemon());
-
-        private ulong pokemonId_;
-
-        public EvolvePokemon()
-        {
-            OnConstruction();
-        }
-
-        public EvolvePokemon(EvolvePokemon other) : this()
-        {
-            pokemonId_ = other.pokemonId_;
-        }
-
-        public static pb::MessageParser<EvolvePokemon> Parser
-        {
-            get { return _parser; }
-        }
-
-        public static pbr::MessageDescriptor Descriptor
-        {
-            get { return global::PokemonGo.RocketAPI.GeneratedCode.PayloadsReflection.Descriptor.MessageTypes[96]; }
-        }
-
-        public ulong PokemonId
-        {
-            get { return pokemonId_; }
-            set { pokemonId_ = value; }
-        }
-
-        pbr::MessageDescriptor pb::IMessage.Descriptor
-        {
-            get { return Descriptor; }
-        }
-
-        public EvolvePokemon Clone()
-        {
-            return new EvolvePokemon(this);
-        }
-
-        public bool Equals(EvolvePokemon other)
-        {
-            if (ReferenceEquals(other, null))
-            {
-                return false;
-            }
-            if (ReferenceEquals(other, this))
-            {
-                return true;
-            }
-            if (PokemonId != other.PokemonId) return false;
-            return true;
-        }
-
-        public void WriteTo(pb::CodedOutputStream output)
-        {
-            if (PokemonId != 0UL)
-            {
-                output.WriteRawTag(9);
-                output.WriteFixed64(PokemonId);
-            }
-        }
-
-        public int CalculateSize()
-        {
-            var size = 0;
-            if (PokemonId != 0UL)
-            {
-                size += 1 + 8;
-            }
-            return size;
-        }
-
-        public void MergeFrom(EvolvePokemon other)
-        {
-            if (other == null)
-            {
-                return;
-            }
-            if (other.PokemonId != 0UL)
-            {
-                PokemonId = other.PokemonId;
-            }
-        }
-
-        public void MergeFrom(pb::CodedInputStream input)
-        {
-            uint tag;
-            while ((tag = input.ReadTag()) != 0)
-            {
-                switch (tag)
-                {
-                    default:
-                        input.SkipLastField();
-                        break;
-                    case 9:
-                        {
-                            PokemonId = input.ReadFixed64();
-                            break;
-                        }
-                }
-            }
-        }
-
-        public override bool Equals(object other)
-        {
-            return Equals(other as EvolvePokemon);
-        }
-
-        public override int GetHashCode()
-        {
-            var hash = 1;
-            if (PokemonId != 0UL) hash ^= PokemonId.GetHashCode();
-            return hash;
-        }
-
-        partial void OnConstruction();
-
-        public override string ToString()
-        {
-            return pb::JsonFormatter.ToDiagnosticString(this);
-        }
-    }
-
-    [global::System.Diagnostics.DebuggerNonUserCodeAttribute()]
-    public sealed partial class EvolvePokemonOut : pb::IMessage<EvolvePokemonOut>
-    {
-        /// <summary>Field number for the "Result" field.</summary>
-        public const int ResultFieldNumber = 1;
-
-        /// <summary>Field number for the "EvolvedPokemon" field.</summary>
-        public const int EvolvedPokemonFieldNumber = 2;
-
-        /// <summary>Field number for the "ExpAwarded" field.</summary>
-        public const int ExpAwardedFieldNumber = 3;
-
-        /// <summary>Field number for the "CandyAwarded" field.</summary>
-        public const int CandyAwardedFieldNumber = 4;
-
-        private static readonly pb::MessageParser<EvolvePokemonOut> _parser =
-            new pb::MessageParser<EvolvePokemonOut>(() => new EvolvePokemonOut());
-
-        private int candyAwarded_;
-        private global::PokemonGo.RocketAPI.GeneratedCode.Pokemon evolvedPokemon_;
-        private int expAwarded_;
-        private global::PokemonGo.RocketAPI.GeneratedCode.EvolvePokemonOut.Types.EvolvePokemonStatus result_ = 0;
-
-        public EvolvePokemonOut()
-        {
-            OnConstruction();
-        }
-
-        public EvolvePokemonOut(EvolvePokemonOut other) : this()
-        {
-            result_ = other.result_;
-            EvolvedPokemon = other.evolvedPokemon_ != null ? other.EvolvedPokemon.Clone() : null;
-            expAwarded_ = other.expAwarded_;
-            candyAwarded_ = other.candyAwarded_;
-        }
-
-        public static pb::MessageParser<EvolvePokemonOut> Parser
-        {
-            get { return _parser; }
-        }
-
-        public static pbr::MessageDescriptor Descriptor
-        {
-            get { return global::PokemonGo.RocketAPI.GeneratedCode.PayloadsReflection.Descriptor.MessageTypes[97]; }
-        }
-
-        public global::PokemonGo.RocketAPI.GeneratedCode.EvolvePokemonOut.Types.EvolvePokemonStatus Result
-        {
-            get { return result_; }
-            set { result_ = value; }
-        }
-
-        public global::PokemonGo.RocketAPI.GeneratedCode.Pokemon EvolvedPokemon
-        {
-            get { return evolvedPokemon_; }
-            set { evolvedPokemon_ = value; }
-        }
-
-        public int ExpAwarded
-        {
-            get { return expAwarded_; }
-            set { expAwarded_ = value; }
-        }
-
-        public int CandyAwarded
-        {
-            get { return candyAwarded_; }
-            set { candyAwarded_ = value; }
-        }
-
-        pbr::MessageDescriptor pb::IMessage.Descriptor
-        {
-            get { return Descriptor; }
-        }
-
-        public EvolvePokemonOut Clone()
-        {
-            return new EvolvePokemonOut(this);
-        }
-
-        public bool Equals(EvolvePokemonOut other)
-        {
-            if (ReferenceEquals(other, null))
-            {
-                return false;
-            }
-            if (ReferenceEquals(other, this))
-            {
-                return true;
-            }
-            if (Result != other.Result) return false;
-            if (!Equals(EvolvedPokemon, other.EvolvedPokemon)) return false;
-            if (ExpAwarded != other.ExpAwarded) return false;
-            if (CandyAwarded != other.CandyAwarded) return false;
-            return true;
-        }
-
-        public void WriteTo(pb::CodedOutputStream output)
-        {
-            if (Result != 0)
-            {
-                output.WriteRawTag(8);
-                output.WriteEnum((int)Result);
-            }
-            if (evolvedPokemon_ != null)
-            {
-                output.WriteRawTag(18);
-                output.WriteMessage(EvolvedPokemon);
-            }
-            if (ExpAwarded != 0)
-            {
-                output.WriteRawTag(24);
-                output.WriteInt32(ExpAwarded);
-            }
-            if (CandyAwarded != 0)
-            {
-                output.WriteRawTag(32);
-                output.WriteInt32(CandyAwarded);
-            }
-        }
-
-        public int CalculateSize()
-        {
-            var size = 0;
-            if (Result != 0)
-            {
-                size += 1 + pb::CodedOutputStream.ComputeEnumSize((int)Result);
-            }
-            if (evolvedPokemon_ != null)
-            {
-                size += 1 + pb::CodedOutputStream.ComputeMessageSize(EvolvedPokemon);
-            }
-            if (ExpAwarded != 0)
-            {
-                size += 1 + pb::CodedOutputStream.ComputeInt32Size(ExpAwarded);
-            }
-            if (CandyAwarded != 0)
-            {
-                size += 1 + pb::CodedOutputStream.ComputeInt32Size(CandyAwarded);
-            }
-            return size;
-        }
-
-        public void MergeFrom(EvolvePokemonOut other)
-        {
-            if (other == null)
-            {
-                return;
-            }
-            if (other.Result != 0)
-            {
-                Result = other.Result;
-            }
-            if (other.evolvedPokemon_ != null)
-            {
-                if (evolvedPokemon_ == null)
-                {
-                    evolvedPokemon_ = new global::PokemonGo.RocketAPI.GeneratedCode.Pokemon();
-                }
-                EvolvedPokemon.MergeFrom(other.EvolvedPokemon);
-            }
-            if (other.ExpAwarded != 0)
-            {
-                ExpAwarded = other.ExpAwarded;
-            }
-            if (other.CandyAwarded != 0)
-            {
-                CandyAwarded = other.CandyAwarded;
-            }
-        }
-
-        public void MergeFrom(pb::CodedInputStream input)
-        {
-            uint tag;
-            while ((tag = input.ReadTag()) != 0)
-            {
-                switch (tag)
-                {
-                    default:
-                        input.SkipLastField();
-                        break;
-                    case 8:
-                        {
-                            result_ =
-                                (global::PokemonGo.RocketAPI.GeneratedCode.EvolvePokemonOut.Types.EvolvePokemonStatus)
-                                    input.ReadEnum();
-                            break;
-                        }
-                    case 18:
-                        {
-                            if (evolvedPokemon_ == null)
-                            {
-                                evolvedPokemon_ = new global::PokemonGo.RocketAPI.GeneratedCode.Pokemon();
-                            }
-                            input.ReadMessage(evolvedPokemon_);
-                            break;
-                        }
-                    case 24:
-                        {
-                            ExpAwarded = input.ReadInt32();
-                            break;
-                        }
-                    case 32:
-                        {
-                            CandyAwarded = input.ReadInt32();
-                            break;
-                        }
-                }
-            }
-        }
-
-        public override bool Equals(object other)
-        {
-            return Equals(other as EvolvePokemonOut);
-        }
-
-        public override int GetHashCode()
-        {
-            var hash = 1;
-            if (Result != 0) hash ^= Result.GetHashCode();
-            if (evolvedPokemon_ != null) hash ^= EvolvedPokemon.GetHashCode();
-            if (ExpAwarded != 0) hash ^= ExpAwarded.GetHashCode();
-            if (CandyAwarded != 0) hash ^= CandyAwarded.GetHashCode();
-            return hash;
-        }
-
-        partial void OnConstruction();
-
-        public override string ToString()
-        {
-            return pb::JsonFormatter.ToDiagnosticString(this);
-        }
-
-        #region Nested types
-
-        /// <summary>Container for nested types declared in the EvolvePokemonOut message type.</summary>
-        [global::System.Diagnostics.DebuggerNonUserCodeAttribute()]
-        public static partial class Types
-        {
-            public enum EvolvePokemonStatus
-            {
-                [pbr::OriginalName("POKEMON_EVOLVED_UNSET")]
-                PokemonEvolvedUnset = 0,
-                [pbr::OriginalName("POKEMON_EVOLVED_SUCCESS")]
-                PokemonEvolvedSuccess = 1,
-                [pbr::OriginalName("FAILED_POKEMON_MISSING")]
-                FailedPokemonMissing = 2,
-                [pbr::OriginalName("FAILED_INSUFFICIENT_RESOURCES")]
-                FailedInsufficientResources = 3,
-                [pbr::OriginalName("FAILED_POKEMON_CANNOT_EVOLVE")]
-                FailedPokemonCannotEvolve = 4,
-                [pbr::OriginalName("FAILED_POKEMON_IS_DEPLOYED")]
-                FailedPokemonIsDeployed = 5,
-            }
-        }
-
-        #endregion
-    }
-
-    #endregion
-}
-
-#endregion Designer generated code
diff --git a/PokemonGo.RocketAPI/GeneratedCode/Request.cs b/PokemonGo.RocketAPI/GeneratedCode/Request.cs
deleted file mode 100644
index a8b1cc7..0000000
--- a/PokemonGo.RocketAPI/GeneratedCode/Request.cs
+++ /dev/null
@@ -1,3394 +0,0 @@
-#pragma warning disable 1591, 0612, 3021
-
-#region Designer generated code
-
-#region
-
-using pb = global::Google.Protobuf;
-using pbc = global::Google.Protobuf.Collections;
-using pbr = global::Google.Protobuf.Reflection;
-using scg = global::System.Collections.Generic;
-
-#endregion
-
-namespace PokemonGo.RocketAPI.GeneratedCode
-{
-    /// <summary>Holder for reflection information generated from Request.proto</summary>
-    [global::System.Diagnostics.DebuggerNonUserCodeAttribute()]
-    public static partial class RequestReflection
-    {
-        #region Descriptor
-
-        /// <summary>File descriptor for Request.proto</summary>
-        public static pbr::FileDescriptor Descriptor
-        {
-            get { return descriptor; }
-        }
-
-        private static pbr::FileDescriptor descriptor;
-
-        static RequestReflection()
-        {
-            var descriptorData = global::System.Convert.FromBase64String(
-                string.Concat(
-                    "Cg1SZXF1ZXN0LnByb3RvEiFQb2tlbW9uR28uUm9ja2V0QVBJLkdlbmVyYXRl",
-                    "ZENvZGUihAwKB1JlcXVlc3QSEAoIdW5rbm93bjEYASABKAUSDgoGcnBjX2lk",
-                    "GAMgASgDEkUKCHJlcXVlc3RzGAQgAygLMjMuUG9rZW1vbkdvLlJvY2tldEFQ",
-                    "SS5HZW5lcmF0ZWRDb2RlLlJlcXVlc3QuUmVxdWVzdHMSRQoIdW5rbm93bjYY",
-                    "BiABKAsyMy5Qb2tlbW9uR28uUm9ja2V0QVBJLkdlbmVyYXRlZENvZGUuUmVx",
-                    "dWVzdC5Vbmtub3duNhIQCghsYXRpdHVkZRgHIAEoBhIRCglsb25naXR1ZGUY",
-                    "CCABKAYSEAoIYWx0aXR1ZGUYCSABKAYSQQoEYXV0aBgKIAEoCzIzLlBva2Vt",
-                    "b25Hby5Sb2NrZXRBUEkuR2VuZXJhdGVkQ29kZS5SZXF1ZXN0LkF1dGhJbmZv",
-                    "EksKC3Vua25vd25hdXRoGAsgASgLMjYuUG9rZW1vbkdvLlJvY2tldEFQSS5H",
-                    "ZW5lcmF0ZWRDb2RlLlJlcXVlc3QuVW5rbm93bkF1dGgSEQoJdW5rbm93bjEy",
-                    "GAwgASgDGkYKC1Vua25vd25BdXRoEhEKCXVua25vd243MRgBIAEoDBIRCgl0",
-                    "aW1lc3RhbXAYAiABKAMSEQoJdW5rbm93bjczGAMgASgMGikKCFJlcXVlc3Rz",
-                    "EgwKBHR5cGUYASABKAUSDwoHbWVzc2FnZRgCIAEoDBocCghVbmtub3duMxIQ",
-                    "Cgh1bmtub3duNBgBIAEoCRqKAQoIVW5rbm93bjYSEAoIdW5rbm93bjEYASAB",
-                    "KAUSTgoIdW5rbm93bjIYAiABKAsyPC5Qb2tlbW9uR28uUm9ja2V0QVBJLkdl",
-                    "bmVyYXRlZENvZGUuUmVxdWVzdC5Vbmtub3duNi5Vbmtub3duMhocCghVbmtu",
-                    "b3duMhIQCgh1bmtub3duMRgBIAEoDBqQAQoIQXV0aEluZm8SEAoIcHJvdmlk",
-                    "ZXIYASABKAkSRgoFdG9rZW4YAiABKAsyNy5Qb2tlbW9uR28uUm9ja2V0QVBJ",
-                    "LkdlbmVyYXRlZENvZGUuUmVxdWVzdC5BdXRoSW5mby5KV1QaKgoDSldUEhAK",
-                    "CGNvbnRlbnRzGAEgASgJEhEKCXVua25vd24xMxgCIAEoBRotChFQbGF5ZXJV",
-                    "cGRhdGVQcm90bxILCgNMYXQYASABKAYSCwoDTG5nGAIgASgGGlwKEU1hcE9i",
-                    "amVjdHNSZXF1ZXN0Eg8KB2NlbGxJZHMYASABKAwSEQoJdW5rbm93bjE0GAIg",
-                    "ASgMEhAKCGxhdGl0dWRlGAMgASgGEhEKCWxvbmdpdHVkZRgEIAEoBhqDAQoR",
-                    "Rm9ydFNlYXJjaFJlcXVlc3QSCgoCSWQYASABKAwSGAoQUGxheWVyTGF0RGVn",
-                    "cmVlcxgCIAEoBhIYChBQbGF5ZXJMbmdEZWdyZWVzGAMgASgGEhYKDkZvcnRM",
-                    "YXREZWdyZWVzGAQgASgGEhYKDkZvcnRMbmdEZWdyZWVzGAUgASgGGkUKEkZv",
-                    "cnREZXRhaWxzUmVxdWVzdBIKCgJJZBgBIAEoDBIQCghMYXRpdHVkZRgCIAEo",
-                    "BhIRCglMb25naXR1ZGUYAyABKAYacQoQRW5jb3VudGVyUmVxdWVzdBITCgtF",
-                    "bmNvdW50ZXJJZBgBIAEoBhIUCgxTcGF3bnBvaW50SWQYAiABKAkSGAoQUGxh",
-                    "eWVyTGF0RGVncmVlcxgDIAEoBhIYChBQbGF5ZXJMbmdEZWdyZWVzGAQgASgG",
-                    "GrwBChNDYXRjaFBva2Vtb25SZXF1ZXN0EhMKC0VuY291bnRlcklkGAEgASgG",
-                    "EhAKCFBva2ViYWxsGAIgASgFEh0KFU5vcm1hbGl6ZWRSZXRpY2xlU2l6ZRgD",
-                    "IAEoBhIWCg5TcGF3blBvaW50R3VpZBgEIAEoCRISCgpIaXRQb2tlbW9uGAUg",
-                    "ASgFEhQKDFNwaW5Nb2RpZmllchgGIAEoBhIdChVOb3JtYWxpemVkSGl0UG9z",
-                    "aXRpb24YByABKAYaHAoMU2V0dGluZ3NHdWlkEgwKBGd1aWQYASABKAwaFAoE",
-                    "VGltZRIMCgR0aW1lGAEgASgDYgZwcm90bzM="));
-            descriptor = pbr::FileDescriptor.FromGeneratedCode(descriptorData,
-                new pbr::FileDescriptor[] {},
-                new pbr::GeneratedClrTypeInfo(null, new pbr::GeneratedClrTypeInfo[]
-                {
-                    new pbr::GeneratedClrTypeInfo(typeof(global::PokemonGo.RocketAPI.GeneratedCode.Request),
-                        global::PokemonGo.RocketAPI.GeneratedCode.Request.Parser,
-                        new[]
-                        {
-                            "Unknown1", "RpcId", "Requests", "Unknown6", "Latitude", "Longitude", "Altitude", "Auth",
-                            "Unknownauth", "Unknown12"
-                        }, null, null, new pbr::GeneratedClrTypeInfo[]
-                        {
-                            new pbr::GeneratedClrTypeInfo(
-                                typeof(global::PokemonGo.RocketAPI.GeneratedCode.Request.Types.UnknownAuth),
-                                global::PokemonGo.RocketAPI.GeneratedCode.Request.Types.UnknownAuth.Parser,
-                                new[] {"Unknown71", "Timestamp", "Unknown73"}, null, null, null),
-                            new pbr::GeneratedClrTypeInfo(
-                                typeof(global::PokemonGo.RocketAPI.GeneratedCode.Request.Types.Requests),
-                                global::PokemonGo.RocketAPI.GeneratedCode.Request.Types.Requests.Parser,
-                                new[] {"Type", "Message"}, null, null, null),
-                            new pbr::GeneratedClrTypeInfo(
-                                typeof(global::PokemonGo.RocketAPI.GeneratedCode.Request.Types.Unknown3),
-                                global::PokemonGo.RocketAPI.GeneratedCode.Request.Types.Unknown3.Parser,
-                                new[] {"Unknown4"}, null, null, null),
-                            new pbr::GeneratedClrTypeInfo(
-                                typeof(global::PokemonGo.RocketAPI.GeneratedCode.Request.Types.Unknown6),
-                                global::PokemonGo.RocketAPI.GeneratedCode.Request.Types.Unknown6.Parser,
-                                new[] {"Unknown1", "Unknown2"}, null, null,
-                                new pbr::GeneratedClrTypeInfo[]
-                                {
-                                    new pbr::GeneratedClrTypeInfo(
-                                        typeof(
-                                            global::PokemonGo.RocketAPI.GeneratedCode.Request.Types.Unknown6.Types.
-                                                Unknown2),
-                                        global::PokemonGo.RocketAPI.GeneratedCode.Request.Types.Unknown6.Types
-                                            .Unknown2.Parser, new[] {"Unknown1"}, null, null, null)
-                                }),
-                            new pbr::GeneratedClrTypeInfo(
-                                typeof(global::PokemonGo.RocketAPI.GeneratedCode.Request.Types.AuthInfo),
-                                global::PokemonGo.RocketAPI.GeneratedCode.Request.Types.AuthInfo.Parser,
-                                new[] {"Provider", "Token"}, null, null,
-                                new pbr::GeneratedClrTypeInfo[]
-                                {
-                                    new pbr::GeneratedClrTypeInfo(
-                                        typeof(
-                                            global::PokemonGo.RocketAPI.GeneratedCode.Request.Types.AuthInfo.Types.
-                                                JWT),
-                                        global::PokemonGo.RocketAPI.GeneratedCode.Request.Types.AuthInfo.Types.JWT
-                                            .Parser, new[] {"Contents", "Unknown13"}, null, null, null)
-                                }),
-                            new pbr::GeneratedClrTypeInfo(
-                                typeof(global::PokemonGo.RocketAPI.GeneratedCode.Request.Types.PlayerUpdateProto),
-                                global::PokemonGo.RocketAPI.GeneratedCode.Request.Types.PlayerUpdateProto.Parser,
-                                new[] {"Lat", "Lng"}, null, null, null),
-                            new pbr::GeneratedClrTypeInfo(
-                                typeof(global::PokemonGo.RocketAPI.GeneratedCode.Request.Types.MapObjectsRequest),
-                                global::PokemonGo.RocketAPI.GeneratedCode.Request.Types.MapObjectsRequest.Parser,
-                                new[] {"CellIds", "Unknown14", "Latitude", "Longitude"}, null, null, null),
-                            new pbr::GeneratedClrTypeInfo(
-                                typeof(global::PokemonGo.RocketAPI.GeneratedCode.Request.Types.FortSearchRequest),
-                                global::PokemonGo.RocketAPI.GeneratedCode.Request.Types.FortSearchRequest.Parser,
-                                new[]
-                                {"Id", "PlayerLatDegrees", "PlayerLngDegrees", "FortLatDegrees", "FortLngDegrees"},
-                                null, null, null),
-                            new pbr::GeneratedClrTypeInfo(
-                                typeof(global::PokemonGo.RocketAPI.GeneratedCode.Request.Types.FortDetailsRequest),
-                                global::PokemonGo.RocketAPI.GeneratedCode.Request.Types.FortDetailsRequest.Parser,
-                                new[] {"Id", "Latitude", "Longitude"}, null, null, null),
-                            new pbr::GeneratedClrTypeInfo(
-                                typeof(global::PokemonGo.RocketAPI.GeneratedCode.Request.Types.EncounterRequest),
-                                global::PokemonGo.RocketAPI.GeneratedCode.Request.Types.EncounterRequest.Parser,
-                                new[] {"EncounterId", "SpawnpointId", "PlayerLatDegrees", "PlayerLngDegrees"}, null,
-                                null, null),
-                            new pbr::GeneratedClrTypeInfo(
-                                typeof(global::PokemonGo.RocketAPI.GeneratedCode.Request.Types.CatchPokemonRequest),
-                                global::PokemonGo.RocketAPI.GeneratedCode.Request.Types.CatchPokemonRequest.Parser,
-                                new[]
-                                {
-                                    "EncounterId", "Pokeball", "NormalizedReticleSize", "SpawnPointGuid", "HitPokemon",
-                                    "SpinModifier", "NormalizedHitPosition"
-                                }, null, null, null),
-                            new pbr::GeneratedClrTypeInfo(
-                                typeof(global::PokemonGo.RocketAPI.GeneratedCode.Request.Types.SettingsGuid),
-                                global::PokemonGo.RocketAPI.GeneratedCode.Request.Types.SettingsGuid.Parser,
-                                new[] {"Guid"}, null, null, null),
-                            new pbr::GeneratedClrTypeInfo(
-                                typeof(global::PokemonGo.RocketAPI.GeneratedCode.Request.Types.Time),
-                                global::PokemonGo.RocketAPI.GeneratedCode.Request.Types.Time.Parser, new[] {"Time_"},
-                                null, null, null)
-                        })
-                }));
-        }
-
-        #endregion
-    }
-
-    #region Messages
-
-    [global::System.Diagnostics.DebuggerNonUserCodeAttribute()]
-    public sealed partial class Request : pb::IMessage<Request>
-    {
-        /// <summary>Field number for the "unknown1" field.</summary>
-        public const int Unknown1FieldNumber = 1;
-
-        /// <summary>Field number for the "rpc_id" field.</summary>
-        public const int RpcIdFieldNumber = 3;
-
-        /// <summary>Field number for the "requests" field.</summary>
-        public const int RequestsFieldNumber = 4;
-
-        /// <summary>Field number for the "unknown6" field.</summary>
-        public const int Unknown6FieldNumber = 6;
-
-        /// <summary>Field number for the "latitude" field.</summary>
-        public const int LatitudeFieldNumber = 7;
-
-        /// <summary>Field number for the "longitude" field.</summary>
-        public const int LongitudeFieldNumber = 8;
-
-        /// <summary>Field number for the "altitude" field.</summary>
-        public const int AltitudeFieldNumber = 9;
-
-        /// <summary>Field number for the "auth" field.</summary>
-        public const int AuthFieldNumber = 10;
-
-        /// <summary>Field number for the "unknownauth" field.</summary>
-        public const int UnknownauthFieldNumber = 11;
-
-        /// <summary>Field number for the "unknown12" field.</summary>
-        public const int Unknown12FieldNumber = 12;
-
-        private static readonly pb::MessageParser<Request> _parser = new pb::MessageParser<Request>(() => new Request());
-
-        private static readonly pb::FieldCodec<global::PokemonGo.RocketAPI.GeneratedCode.Request.Types.Requests>
-            _repeated_requests_codec
-                = pb::FieldCodec.ForMessage(34, global::PokemonGo.RocketAPI.GeneratedCode.Request.Types.Requests.Parser);
-
-        private readonly pbc::RepeatedField<global::PokemonGo.RocketAPI.GeneratedCode.Request.Types.Requests> requests_
-            = new pbc::RepeatedField<global::PokemonGo.RocketAPI.GeneratedCode.Request.Types.Requests>();
-
-        private ulong altitude_;
-        private global::PokemonGo.RocketAPI.GeneratedCode.Request.Types.AuthInfo auth_;
-        private ulong latitude_;
-        private ulong longitude_;
-        private long rpcId_;
-        private int unknown1_;
-        private long unknown12_;
-        private global::PokemonGo.RocketAPI.GeneratedCode.Request.Types.Unknown6 unknown6_;
-        private global::PokemonGo.RocketAPI.GeneratedCode.Request.Types.UnknownAuth unknownauth_;
-
-        public Request()
-        {
-            OnConstruction();
-        }
-
-        public Request(Request other) : this()
-        {
-            unknown1_ = other.unknown1_;
-            rpcId_ = other.rpcId_;
-            requests_ = other.requests_.Clone();
-            Unknown6 = other.unknown6_ != null ? other.Unknown6.Clone() : null;
-            latitude_ = other.latitude_;
-            longitude_ = other.longitude_;
-            altitude_ = other.altitude_;
-            Auth = other.auth_ != null ? other.Auth.Clone() : null;
-            Unknownauth = other.unknownauth_ != null ? other.Unknownauth.Clone() : null;
-            unknown12_ = other.unknown12_;
-        }
-
-        public static pb::MessageParser<Request> Parser
-        {
-            get { return _parser; }
-        }
-
-        public static pbr::MessageDescriptor Descriptor
-        {
-            get { return global::PokemonGo.RocketAPI.GeneratedCode.RequestReflection.Descriptor.MessageTypes[0]; }
-        }
-
-        public int Unknown1
-        {
-            get { return unknown1_; }
-            set { unknown1_ = value; }
-        }
-
-        public long RpcId
-        {
-            get { return rpcId_; }
-            set { rpcId_ = value; }
-        }
-
-        public pbc::RepeatedField<global::PokemonGo.RocketAPI.GeneratedCode.Request.Types.Requests> Requests
-        {
-            get { return requests_; }
-        }
-
-        public global::PokemonGo.RocketAPI.GeneratedCode.Request.Types.Unknown6 Unknown6
-        {
-            get { return unknown6_; }
-            set { unknown6_ = value; }
-        }
-
-        public ulong Latitude
-        {
-            get { return latitude_; }
-            set { latitude_ = value; }
-        }
-
-        public ulong Longitude
-        {
-            get { return longitude_; }
-            set { longitude_ = value; }
-        }
-
-        public ulong Altitude
-        {
-            get { return altitude_; }
-            set { altitude_ = value; }
-        }
-
-        public global::PokemonGo.RocketAPI.GeneratedCode.Request.Types.AuthInfo Auth
-        {
-            get { return auth_; }
-            set { auth_ = value; }
-        }
-
-        public global::PokemonGo.RocketAPI.GeneratedCode.Request.Types.UnknownAuth Unknownauth
-        {
-            get { return unknownauth_; }
-            set { unknownauth_ = value; }
-        }
-
-        public long Unknown12
-        {
-            get { return unknown12_; }
-            set { unknown12_ = value; }
-        }
-
-        pbr::MessageDescriptor pb::IMessage.Descriptor
-        {
-            get { return Descriptor; }
-        }
-
-        public Request Clone()
-        {
-            return new Request(this);
-        }
-
-        public bool Equals(Request other)
-        {
-            if (ReferenceEquals(other, null))
-            {
-                return false;
-            }
-            if (ReferenceEquals(other, this))
-            {
-                return true;
-            }
-            if (Unknown1 != other.Unknown1) return false;
-            if (RpcId != other.RpcId) return false;
-            if (!requests_.Equals(other.requests_)) return false;
-            if (!Equals(Unknown6, other.Unknown6)) return false;
-            if (Latitude != other.Latitude) return false;
-            if (Longitude != other.Longitude) return false;
-            if (Altitude != other.Altitude) return false;
-            if (!Equals(Auth, other.Auth)) return false;
-            if (!Equals(Unknownauth, other.Unknownauth)) return false;
-            if (Unknown12 != other.Unknown12) return false;
-            return true;
-        }
-
-        public void WriteTo(pb::CodedOutputStream output)
-        {
-            if (Unknown1 != 0)
-            {
-                output.WriteRawTag(8);
-                output.WriteInt32(Unknown1);
-            }
-            if (RpcId != 0L)
-            {
-                output.WriteRawTag(24);
-                output.WriteInt64(RpcId);
-            }
-            requests_.WriteTo(output, _repeated_requests_codec);
-            if (unknown6_ != null)
-            {
-                output.WriteRawTag(50);
-                output.WriteMessage(Unknown6);
-            }
-            if (Latitude != 0UL)
-            {
-                output.WriteRawTag(57);
-                output.WriteFixed64(Latitude);
-            }
-            if (Longitude != 0UL)
-            {
-                output.WriteRawTag(65);
-                output.WriteFixed64(Longitude);
-            }
-            if (Altitude != 0UL)
-            {
-                output.WriteRawTag(73);
-                output.WriteFixed64(Altitude);
-            }
-            if (auth_ != null)
-            {
-                output.WriteRawTag(82);
-                output.WriteMessage(Auth);
-            }
-            if (unknownauth_ != null)
-            {
-                output.WriteRawTag(90);
-                output.WriteMessage(Unknownauth);
-            }
-            if (Unknown12 != 0L)
-            {
-                output.WriteRawTag(96);
-                output.WriteInt64(Unknown12);
-            }
-        }
-
-        public int CalculateSize()
-        {
-            var size = 0;
-            if (Unknown1 != 0)
-            {
-                size += 1 + pb::CodedOutputStream.ComputeInt32Size(Unknown1);
-            }
-            if (RpcId != 0L)
-            {
-                size += 1 + pb::CodedOutputStream.ComputeInt64Size(RpcId);
-            }
-            size += requests_.CalculateSize(_repeated_requests_codec);
-            if (unknown6_ != null)
-            {
-                size += 1 + pb::CodedOutputStream.ComputeMessageSize(Unknown6);
-            }
-            if (Latitude != 0UL)
-            {
-                size += 1 + 8;
-            }
-            if (Longitude != 0UL)
-            {
-                size += 1 + 8;
-            }
-            if (Altitude != 0UL)
-            {
-                size += 1 + 8;
-            }
-            if (auth_ != null)
-            {
-                size += 1 + pb::CodedOutputStream.ComputeMessageSize(Auth);
-            }
-            if (unknownauth_ != null)
-            {
-                size += 1 + pb::CodedOutputStream.ComputeMessageSize(Unknownauth);
-            }
-            if (Unknown12 != 0L)
-            {
-                size += 1 + pb::CodedOutputStream.ComputeInt64Size(Unknown12);
-            }
-            return size;
-        }
-
-        public void MergeFrom(Request other)
-        {
-            if (other == null)
-            {
-                return;
-            }
-            if (other.Unknown1 != 0)
-            {
-                Unknown1 = other.Unknown1;
-            }
-            if (other.RpcId != 0L)
-            {
-                RpcId = other.RpcId;
-            }
-            requests_.Add(other.requests_);
-            if (other.unknown6_ != null)
-            {
-                if (unknown6_ == null)
-                {
-                    unknown6_ = new global::PokemonGo.RocketAPI.GeneratedCode.Request.Types.Unknown6();
-                }
-                Unknown6.MergeFrom(other.Unknown6);
-            }
-            if (other.Latitude != 0UL)
-            {
-                Latitude = other.Latitude;
-            }
-            if (other.Longitude != 0UL)
-            {
-                Longitude = other.Longitude;
-            }
-            if (other.Altitude != 0UL)
-            {
-                Altitude = other.Altitude;
-            }
-            if (other.auth_ != null)
-            {
-                if (auth_ == null)
-                {
-                    auth_ = new global::PokemonGo.RocketAPI.GeneratedCode.Request.Types.AuthInfo();
-                }
-                Auth.MergeFrom(other.Auth);
-            }
-            if (other.unknownauth_ != null)
-            {
-                if (unknownauth_ == null)
-                {
-                    unknownauth_ = new global::PokemonGo.RocketAPI.GeneratedCode.Request.Types.UnknownAuth();
-                }
-                Unknownauth.MergeFrom(other.Unknownauth);
-            }
-            if (other.Unknown12 != 0L)
-            {
-                Unknown12 = other.Unknown12;
-            }
-        }
-
-        public void MergeFrom(pb::CodedInputStream input)
-        {
-            uint tag;
-            while ((tag = input.ReadTag()) != 0)
-            {
-                switch (tag)
-                {
-                    default:
-                        input.SkipLastField();
-                        break;
-                    case 8:
-                    {
-                        Unknown1 = input.ReadInt32();
-                        break;
-                    }
-                    case 24:
-                    {
-                        RpcId = input.ReadInt64();
-                        break;
-                    }
-                    case 34:
-                    {
-                        requests_.AddEntriesFrom(input, _repeated_requests_codec);
-                        break;
-                    }
-                    case 50:
-                    {
-                        if (unknown6_ == null)
-                        {
-                            unknown6_ = new global::PokemonGo.RocketAPI.GeneratedCode.Request.Types.Unknown6();
-                        }
-                        input.ReadMessage(unknown6_);
-                        break;
-                    }
-                    case 57:
-                    {
-                        Latitude = input.ReadFixed64();
-                        break;
-                    }
-                    case 65:
-                    {
-                        Longitude = input.ReadFixed64();
-                        break;
-                    }
-                    case 73:
-                    {
-                        Altitude = input.ReadFixed64();
-                        break;
-                    }
-                    case 82:
-                    {
-                        if (auth_ == null)
-                        {
-                            auth_ = new global::PokemonGo.RocketAPI.GeneratedCode.Request.Types.AuthInfo();
-                        }
-                        input.ReadMessage(auth_);
-                        break;
-                    }
-                    case 90:
-                    {
-                        if (unknownauth_ == null)
-                        {
-                            unknownauth_ = new global::PokemonGo.RocketAPI.GeneratedCode.Request.Types.UnknownAuth();
-                        }
-                        input.ReadMessage(unknownauth_);
-                        break;
-                    }
-                    case 96:
-                    {
-                        Unknown12 = input.ReadInt64();
-                        break;
-                    }
-                }
-            }
-        }
-
-        public override bool Equals(object other)
-        {
-            return Equals(other as Request);
-        }
-
-        public override int GetHashCode()
-        {
-            var hash = 1;
-            if (Unknown1 != 0) hash ^= Unknown1.GetHashCode();
-            if (RpcId != 0L) hash ^= RpcId.GetHashCode();
-            hash ^= requests_.GetHashCode();
-            if (unknown6_ != null) hash ^= Unknown6.GetHashCode();
-            if (Latitude != 0UL) hash ^= Latitude.GetHashCode();
-            if (Longitude != 0UL) hash ^= Longitude.GetHashCode();
-            if (Altitude != 0UL) hash ^= Altitude.GetHashCode();
-            if (auth_ != null) hash ^= Auth.GetHashCode();
-            if (unknownauth_ != null) hash ^= Unknownauth.GetHashCode();
-            if (Unknown12 != 0L) hash ^= Unknown12.GetHashCode();
-            return hash;
-        }
-
-        partial void OnConstruction();
-
-        public override string ToString()
-        {
-            return pb::JsonFormatter.ToDiagnosticString(this);
-        }
-
-        #region Nested types
-
-        /// <summary>Container for nested types declared in the Request message type.</summary>
-        [global::System.Diagnostics.DebuggerNonUserCodeAttribute()]
-        public static partial class Types
-        {
-            [global::System.Diagnostics.DebuggerNonUserCodeAttribute()]
-            public sealed partial class UnknownAuth : pb::IMessage<UnknownAuth>
-            {
-                /// <summary>Field number for the "unknown71" field.</summary>
-                public const int Unknown71FieldNumber = 1;
-
-                /// <summary>Field number for the "timestamp" field.</summary>
-                public const int TimestampFieldNumber = 2;
-
-                /// <summary>Field number for the "unknown73" field.</summary>
-                public const int Unknown73FieldNumber = 3;
-
-                private static readonly pb::MessageParser<UnknownAuth> _parser =
-                    new pb::MessageParser<UnknownAuth>(() => new UnknownAuth());
-
-                private long timestamp_;
-                private pb::ByteString unknown71_ = pb::ByteString.Empty;
-                private pb::ByteString unknown73_ = pb::ByteString.Empty;
-
-                public UnknownAuth()
-                {
-                    OnConstruction();
-                }
-
-                public UnknownAuth(UnknownAuth other) : this()
-                {
-                    unknown71_ = other.unknown71_;
-                    timestamp_ = other.timestamp_;
-                    unknown73_ = other.unknown73_;
-                }
-
-                public static pb::MessageParser<UnknownAuth> Parser
-                {
-                    get { return _parser; }
-                }
-
-                public static pbr::MessageDescriptor Descriptor
-                {
-                    get { return global::PokemonGo.RocketAPI.GeneratedCode.Request.Descriptor.NestedTypes[0]; }
-                }
-
-                public pb::ByteString Unknown71
-                {
-                    get { return unknown71_; }
-                    set { unknown71_ = pb::ProtoPreconditions.CheckNotNull(value, "value"); }
-                }
-
-                public long Timestamp
-                {
-                    get { return timestamp_; }
-                    set { timestamp_ = value; }
-                }
-
-                public pb::ByteString Unknown73
-                {
-                    get { return unknown73_; }
-                    set { unknown73_ = pb::ProtoPreconditions.CheckNotNull(value, "value"); }
-                }
-
-                pbr::MessageDescriptor pb::IMessage.Descriptor
-                {
-                    get { return Descriptor; }
-                }
-
-                public UnknownAuth Clone()
-                {
-                    return new UnknownAuth(this);
-                }
-
-                public bool Equals(UnknownAuth other)
-                {
-                    if (ReferenceEquals(other, null))
-                    {
-                        return false;
-                    }
-                    if (ReferenceEquals(other, this))
-                    {
-                        return true;
-                    }
-                    if (Unknown71 != other.Unknown71) return false;
-                    if (Timestamp != other.Timestamp) return false;
-                    if (Unknown73 != other.Unknown73) return false;
-                    return true;
-                }
-
-                public void WriteTo(pb::CodedOutputStream output)
-                {
-                    if (Unknown71.Length != 0)
-                    {
-                        output.WriteRawTag(10);
-                        output.WriteBytes(Unknown71);
-                    }
-                    if (Timestamp != 0L)
-                    {
-                        output.WriteRawTag(16);
-                        output.WriteInt64(Timestamp);
-                    }
-                    if (Unknown73.Length != 0)
-                    {
-                        output.WriteRawTag(26);
-                        output.WriteBytes(Unknown73);
-                    }
-                }
-
-                public int CalculateSize()
-                {
-                    var size = 0;
-                    if (Unknown71.Length != 0)
-                    {
-                        size += 1 + pb::CodedOutputStream.ComputeBytesSize(Unknown71);
-                    }
-                    if (Timestamp != 0L)
-                    {
-                        size += 1 + pb::CodedOutputStream.ComputeInt64Size(Timestamp);
-                    }
-                    if (Unknown73.Length != 0)
-                    {
-                        size += 1 + pb::CodedOutputStream.ComputeBytesSize(Unknown73);
-                    }
-                    return size;
-                }
-
-                public void MergeFrom(UnknownAuth other)
-                {
-                    if (other == null)
-                    {
-                        return;
-                    }
-                    if (other.Unknown71.Length != 0)
-                    {
-                        Unknown71 = other.Unknown71;
-                    }
-                    if (other.Timestamp != 0L)
-                    {
-                        Timestamp = other.Timestamp;
-                    }
-                    if (other.Unknown73.Length != 0)
-                    {
-                        Unknown73 = other.Unknown73;
-                    }
-                }
-
-                public void MergeFrom(pb::CodedInputStream input)
-                {
-                    uint tag;
-                    while ((tag = input.ReadTag()) != 0)
-                    {
-                        switch (tag)
-                        {
-                            default:
-                                input.SkipLastField();
-                                break;
-                            case 10:
-                            {
-                                Unknown71 = input.ReadBytes();
-                                break;
-                            }
-                            case 16:
-                            {
-                                Timestamp = input.ReadInt64();
-                                break;
-                            }
-                            case 26:
-                            {
-                                Unknown73 = input.ReadBytes();
-                                break;
-                            }
-                        }
-                    }
-                }
-
-                public override bool Equals(object other)
-                {
-                    return Equals(other as UnknownAuth);
-                }
-
-                public override int GetHashCode()
-                {
-                    var hash = 1;
-                    if (Unknown71.Length != 0) hash ^= Unknown71.GetHashCode();
-                    if (Timestamp != 0L) hash ^= Timestamp.GetHashCode();
-                    if (Unknown73.Length != 0) hash ^= Unknown73.GetHashCode();
-                    return hash;
-                }
-
-                partial void OnConstruction();
-
-                public override string ToString()
-                {
-                    return pb::JsonFormatter.ToDiagnosticString(this);
-                }
-            }
-
-            [global::System.Diagnostics.DebuggerNonUserCodeAttribute()]
-            public sealed partial class Requests : pb::IMessage<Requests>
-            {
-                /// <summary>Field number for the "type" field.</summary>
-                public const int TypeFieldNumber = 1;
-
-                /// <summary>Field number for the "message" field.</summary>
-                public const int MessageFieldNumber = 2;
-
-                private static readonly pb::MessageParser<Requests> _parser =
-                    new pb::MessageParser<Requests>(() => new Requests());
-
-                private pb::ByteString message_ = pb::ByteString.Empty;
-                private int type_;
-
-                public Requests()
-                {
-                    OnConstruction();
-                }
-
-                public Requests(Requests other) : this()
-                {
-                    type_ = other.type_;
-                    message_ = other.message_;
-                }
-
-                public static pb::MessageParser<Requests> Parser
-                {
-                    get { return _parser; }
-                }
-
-                public static pbr::MessageDescriptor Descriptor
-                {
-                    get { return global::PokemonGo.RocketAPI.GeneratedCode.Request.Descriptor.NestedTypes[1]; }
-                }
-
-                public int Type
-                {
-                    get { return type_; }
-                    set { type_ = value; }
-                }
-
-                public pb::ByteString Message
-                {
-                    get { return message_; }
-                    set { message_ = pb::ProtoPreconditions.CheckNotNull(value, "value"); }
-                }
-
-                pbr::MessageDescriptor pb::IMessage.Descriptor
-                {
-                    get { return Descriptor; }
-                }
-
-                public Requests Clone()
-                {
-                    return new Requests(this);
-                }
-
-                public bool Equals(Requests other)
-                {
-                    if (ReferenceEquals(other, null))
-                    {
-                        return false;
-                    }
-                    if (ReferenceEquals(other, this))
-                    {
-                        return true;
-                    }
-                    if (Type != other.Type) return false;
-                    if (Message != other.Message) return false;
-                    return true;
-                }
-
-                public void WriteTo(pb::CodedOutputStream output)
-                {
-                    if (Type != 0)
-                    {
-                        output.WriteRawTag(8);
-                        output.WriteInt32(Type);
-                    }
-                    if (Message.Length != 0)
-                    {
-                        output.WriteRawTag(18);
-                        output.WriteBytes(Message);
-                    }
-                }
-
-                public int CalculateSize()
-                {
-                    var size = 0;
-                    if (Type != 0)
-                    {
-                        size += 1 + pb::CodedOutputStream.ComputeInt32Size(Type);
-                    }
-                    if (Message.Length != 0)
-                    {
-                        size += 1 + pb::CodedOutputStream.ComputeBytesSize(Message);
-                    }
-                    return size;
-                }
-
-                public void MergeFrom(Requests other)
-                {
-                    if (other == null)
-                    {
-                        return;
-                    }
-                    if (other.Type != 0)
-                    {
-                        Type = other.Type;
-                    }
-                    if (other.Message.Length != 0)
-                    {
-                        Message = other.Message;
-                    }
-                }
-
-                public void MergeFrom(pb::CodedInputStream input)
-                {
-                    uint tag;
-                    while ((tag = input.ReadTag()) != 0)
-                    {
-                        switch (tag)
-                        {
-                            default:
-                                input.SkipLastField();
-                                break;
-                            case 8:
-                            {
-                                Type = input.ReadInt32();
-                                break;
-                            }
-                            case 18:
-                            {
-                                Message = input.ReadBytes();
-                                break;
-                            }
-                        }
-                    }
-                }
-
-                public override bool Equals(object other)
-                {
-                    return Equals(other as Requests);
-                }
-
-                public override int GetHashCode()
-                {
-                    var hash = 1;
-                    if (Type != 0) hash ^= Type.GetHashCode();
-                    if (Message.Length != 0) hash ^= Message.GetHashCode();
-                    return hash;
-                }
-
-                partial void OnConstruction();
-
-                public override string ToString()
-                {
-                    return pb::JsonFormatter.ToDiagnosticString(this);
-                }
-            }
-
-            [global::System.Diagnostics.DebuggerNonUserCodeAttribute()]
-            public sealed partial class Unknown3 : pb::IMessage<Unknown3>
-            {
-                /// <summary>Field number for the "unknown4" field.</summary>
-                public const int Unknown4FieldNumber = 1;
-
-                private static readonly pb::MessageParser<Unknown3> _parser =
-                    new pb::MessageParser<Unknown3>(() => new Unknown3());
-
-                private string unknown4_ = "";
-
-                public Unknown3()
-                {
-                    OnConstruction();
-                }
-
-                public Unknown3(Unknown3 other) : this()
-                {
-                    unknown4_ = other.unknown4_;
-                }
-
-                public static pb::MessageParser<Unknown3> Parser
-                {
-                    get { return _parser; }
-                }
-
-                public static pbr::MessageDescriptor Descriptor
-                {
-                    get { return global::PokemonGo.RocketAPI.GeneratedCode.Request.Descriptor.NestedTypes[2]; }
-                }
-
-                public string Unknown4
-                {
-                    get { return unknown4_; }
-                    set { unknown4_ = pb::ProtoPreconditions.CheckNotNull(value, "value"); }
-                }
-
-                pbr::MessageDescriptor pb::IMessage.Descriptor
-                {
-                    get { return Descriptor; }
-                }
-
-                public Unknown3 Clone()
-                {
-                    return new Unknown3(this);
-                }
-
-                public bool Equals(Unknown3 other)
-                {
-                    if (ReferenceEquals(other, null))
-                    {
-                        return false;
-                    }
-                    if (ReferenceEquals(other, this))
-                    {
-                        return true;
-                    }
-                    if (Unknown4 != other.Unknown4) return false;
-                    return true;
-                }
-
-                public void WriteTo(pb::CodedOutputStream output)
-                {
-                    if (Unknown4.Length != 0)
-                    {
-                        output.WriteRawTag(10);
-                        output.WriteString(Unknown4);
-                    }
-                }
-
-                public int CalculateSize()
-                {
-                    var size = 0;
-                    if (Unknown4.Length != 0)
-                    {
-                        size += 1 + pb::CodedOutputStream.ComputeStringSize(Unknown4);
-                    }
-                    return size;
-                }
-
-                public void MergeFrom(Unknown3 other)
-                {
-                    if (other == null)
-                    {
-                        return;
-                    }
-                    if (other.Unknown4.Length != 0)
-                    {
-                        Unknown4 = other.Unknown4;
-                    }
-                }
-
-                public void MergeFrom(pb::CodedInputStream input)
-                {
-                    uint tag;
-                    while ((tag = input.ReadTag()) != 0)
-                    {
-                        switch (tag)
-                        {
-                            default:
-                                input.SkipLastField();
-                                break;
-                            case 10:
-                            {
-                                Unknown4 = input.ReadString();
-                                break;
-                            }
-                        }
-                    }
-                }
-
-                public override bool Equals(object other)
-                {
-                    return Equals(other as Unknown3);
-                }
-
-                public override int GetHashCode()
-                {
-                    var hash = 1;
-                    if (Unknown4.Length != 0) hash ^= Unknown4.GetHashCode();
-                    return hash;
-                }
-
-                partial void OnConstruction();
-
-                public override string ToString()
-                {
-                    return pb::JsonFormatter.ToDiagnosticString(this);
-                }
-            }
-
-            [global::System.Diagnostics.DebuggerNonUserCodeAttribute()]
-            public sealed partial class Unknown6 : pb::IMessage<Unknown6>
-            {
-                /// <summary>Field number for the "unknown1" field.</summary>
-                public const int Unknown1FieldNumber = 1;
-
-                /// <summary>Field number for the "unknown2" field.</summary>
-                public const int Unknown2FieldNumber = 2;
-
-                private static readonly pb::MessageParser<Unknown6> _parser =
-                    new pb::MessageParser<Unknown6>(() => new Unknown6());
-
-                private int unknown1_;
-                private global::PokemonGo.RocketAPI.GeneratedCode.Request.Types.Unknown6.Types.Unknown2 unknown2_;
-
-                public Unknown6()
-                {
-                    OnConstruction();
-                }
-
-                public Unknown6(Unknown6 other) : this()
-                {
-                    unknown1_ = other.unknown1_;
-                    Unknown2 = other.unknown2_ != null ? other.Unknown2.Clone() : null;
-                }
-
-                public static pb::MessageParser<Unknown6> Parser
-                {
-                    get { return _parser; }
-                }
-
-                public static pbr::MessageDescriptor Descriptor
-                {
-                    get { return global::PokemonGo.RocketAPI.GeneratedCode.Request.Descriptor.NestedTypes[3]; }
-                }
-
-                public int Unknown1
-                {
-                    get { return unknown1_; }
-                    set { unknown1_ = value; }
-                }
-
-                public global::PokemonGo.RocketAPI.GeneratedCode.Request.Types.Unknown6.Types.Unknown2 Unknown2
-                {
-                    get { return unknown2_; }
-                    set { unknown2_ = value; }
-                }
-
-                pbr::MessageDescriptor pb::IMessage.Descriptor
-                {
-                    get { return Descriptor; }
-                }
-
-                public Unknown6 Clone()
-                {
-                    return new Unknown6(this);
-                }
-
-                public bool Equals(Unknown6 other)
-                {
-                    if (ReferenceEquals(other, null))
-                    {
-                        return false;
-                    }
-                    if (ReferenceEquals(other, this))
-                    {
-                        return true;
-                    }
-                    if (Unknown1 != other.Unknown1) return false;
-                    if (!Equals(Unknown2, other.Unknown2)) return false;
-                    return true;
-                }
-
-                public void WriteTo(pb::CodedOutputStream output)
-                {
-                    if (Unknown1 != 0)
-                    {
-                        output.WriteRawTag(8);
-                        output.WriteInt32(Unknown1);
-                    }
-                    if (unknown2_ != null)
-                    {
-                        output.WriteRawTag(18);
-                        output.WriteMessage(Unknown2);
-                    }
-                }
-
-                public int CalculateSize()
-                {
-                    var size = 0;
-                    if (Unknown1 != 0)
-                    {
-                        size += 1 + pb::CodedOutputStream.ComputeInt32Size(Unknown1);
-                    }
-                    if (unknown2_ != null)
-                    {
-                        size += 1 + pb::CodedOutputStream.ComputeMessageSize(Unknown2);
-                    }
-                    return size;
-                }
-
-                public void MergeFrom(Unknown6 other)
-                {
-                    if (other == null)
-                    {
-                        return;
-                    }
-                    if (other.Unknown1 != 0)
-                    {
-                        Unknown1 = other.Unknown1;
-                    }
-                    if (other.unknown2_ != null)
-                    {
-                        if (unknown2_ == null)
-                        {
-                            unknown2_ =
-                                new global::PokemonGo.RocketAPI.GeneratedCode.Request.Types.Unknown6.Types.Unknown2();
-                        }
-                        Unknown2.MergeFrom(other.Unknown2);
-                    }
-                }
-
-                public void MergeFrom(pb::CodedInputStream input)
-                {
-                    uint tag;
-                    while ((tag = input.ReadTag()) != 0)
-                    {
-                        switch (tag)
-                        {
-                            default:
-                                input.SkipLastField();
-                                break;
-                            case 8:
-                            {
-                                Unknown1 = input.ReadInt32();
-                                break;
-                            }
-                            case 18:
-                            {
-                                if (unknown2_ == null)
-                                {
-                                    unknown2_ =
-                                        new global::PokemonGo.RocketAPI.GeneratedCode.Request.Types.Unknown6.Types.
-                                            Unknown2();
-                                }
-                                input.ReadMessage(unknown2_);
-                                break;
-                            }
-                        }
-                    }
-                }
-
-                public override bool Equals(object other)
-                {
-                    return Equals(other as Unknown6);
-                }
-
-                public override int GetHashCode()
-                {
-                    var hash = 1;
-                    if (Unknown1 != 0) hash ^= Unknown1.GetHashCode();
-                    if (unknown2_ != null) hash ^= Unknown2.GetHashCode();
-                    return hash;
-                }
-
-                partial void OnConstruction();
-
-                public override string ToString()
-                {
-                    return pb::JsonFormatter.ToDiagnosticString(this);
-                }
-
-                #region Nested types
-
-                /// <summary>Container for nested types declared in the Unknown6 message type.</summary>
-                [global::System.Diagnostics.DebuggerNonUserCodeAttribute()]
-                public static partial class Types
-                {
-                    [global::System.Diagnostics.DebuggerNonUserCodeAttribute()]
-                    public sealed partial class Unknown2 : pb::IMessage<Unknown2>
-                    {
-                        /// <summary>Field number for the "unknown1" field.</summary>
-                        public const int Unknown1FieldNumber = 1;
-
-                        private static readonly pb::MessageParser<Unknown2> _parser =
-                            new pb::MessageParser<Unknown2>(() => new Unknown2());
-
-                        private pb::ByteString unknown1_ = pb::ByteString.Empty;
-
-                        public Unknown2()
-                        {
-                            OnConstruction();
-                        }
-
-                        public Unknown2(Unknown2 other) : this()
-                        {
-                            unknown1_ = other.unknown1_;
-                        }
-
-                        public static pb::MessageParser<Unknown2> Parser
-                        {
-                            get { return _parser; }
-                        }
-
-                        public static pbr::MessageDescriptor Descriptor
-                        {
-                            get
-                            {
-                                return
-                                    global::PokemonGo.RocketAPI.GeneratedCode.Request.Types.Unknown6.Descriptor
-                                        .NestedTypes[0];
-                            }
-                        }
-
-                        public pb::ByteString Unknown1
-                        {
-                            get { return unknown1_; }
-                            set { unknown1_ = pb::ProtoPreconditions.CheckNotNull(value, "value"); }
-                        }
-
-                        pbr::MessageDescriptor pb::IMessage.Descriptor
-                        {
-                            get { return Descriptor; }
-                        }
-
-                        public Unknown2 Clone()
-                        {
-                            return new Unknown2(this);
-                        }
-
-                        public bool Equals(Unknown2 other)
-                        {
-                            if (ReferenceEquals(other, null))
-                            {
-                                return false;
-                            }
-                            if (ReferenceEquals(other, this))
-                            {
-                                return true;
-                            }
-                            if (Unknown1 != other.Unknown1) return false;
-                            return true;
-                        }
-
-                        public void WriteTo(pb::CodedOutputStream output)
-                        {
-                            if (Unknown1.Length != 0)
-                            {
-                                output.WriteRawTag(10);
-                                output.WriteBytes(Unknown1);
-                            }
-                        }
-
-                        public int CalculateSize()
-                        {
-                            var size = 0;
-                            if (Unknown1.Length != 0)
-                            {
-                                size += 1 + pb::CodedOutputStream.ComputeBytesSize(Unknown1);
-                            }
-                            return size;
-                        }
-
-                        public void MergeFrom(Unknown2 other)
-                        {
-                            if (other == null)
-                            {
-                                return;
-                            }
-                            if (other.Unknown1.Length != 0)
-                            {
-                                Unknown1 = other.Unknown1;
-                            }
-                        }
-
-                        public void MergeFrom(pb::CodedInputStream input)
-                        {
-                            uint tag;
-                            while ((tag = input.ReadTag()) != 0)
-                            {
-                                switch (tag)
-                                {
-                                    default:
-                                        input.SkipLastField();
-                                        break;
-                                    case 10:
-                                    {
-                                        Unknown1 = input.ReadBytes();
-                                        break;
-                                    }
-                                }
-                            }
-                        }
-
-                        public override bool Equals(object other)
-                        {
-                            return Equals(other as Unknown2);
-                        }
-
-                        public override int GetHashCode()
-                        {
-                            var hash = 1;
-                            if (Unknown1.Length != 0) hash ^= Unknown1.GetHashCode();
-                            return hash;
-                        }
-
-                        partial void OnConstruction();
-
-                        public override string ToString()
-                        {
-                            return pb::JsonFormatter.ToDiagnosticString(this);
-                        }
-                    }
-                }
-
-                #endregion
-            }
-
-            [global::System.Diagnostics.DebuggerNonUserCodeAttribute()]
-            public sealed partial class AuthInfo : pb::IMessage<AuthInfo>
-            {
-                /// <summary>Field number for the "provider" field.</summary>
-                public const int ProviderFieldNumber = 1;
-
-                /// <summary>Field number for the "token" field.</summary>
-                public const int TokenFieldNumber = 2;
-
-                private static readonly pb::MessageParser<AuthInfo> _parser =
-                    new pb::MessageParser<AuthInfo>(() => new AuthInfo());
-
-                private string provider_ = "";
-                private global::PokemonGo.RocketAPI.GeneratedCode.Request.Types.AuthInfo.Types.JWT token_;
-
-                public AuthInfo()
-                {
-                    OnConstruction();
-                }
-
-                public AuthInfo(AuthInfo other) : this()
-                {
-                    provider_ = other.provider_;
-                    Token = other.token_ != null ? other.Token.Clone() : null;
-                }
-
-                public static pb::MessageParser<AuthInfo> Parser
-                {
-                    get { return _parser; }
-                }
-
-                public static pbr::MessageDescriptor Descriptor
-                {
-                    get { return global::PokemonGo.RocketAPI.GeneratedCode.Request.Descriptor.NestedTypes[4]; }
-                }
-
-                public string Provider
-                {
-                    get { return provider_; }
-                    set { provider_ = pb::ProtoPreconditions.CheckNotNull(value, "value"); }
-                }
-
-                public global::PokemonGo.RocketAPI.GeneratedCode.Request.Types.AuthInfo.Types.JWT Token
-                {
-                    get { return token_; }
-                    set { token_ = value; }
-                }
-
-                pbr::MessageDescriptor pb::IMessage.Descriptor
-                {
-                    get { return Descriptor; }
-                }
-
-                public AuthInfo Clone()
-                {
-                    return new AuthInfo(this);
-                }
-
-                public bool Equals(AuthInfo other)
-                {
-                    if (ReferenceEquals(other, null))
-                    {
-                        return false;
-                    }
-                    if (ReferenceEquals(other, this))
-                    {
-                        return true;
-                    }
-                    if (Provider != other.Provider) return false;
-                    if (!Equals(Token, other.Token)) return false;
-                    return true;
-                }
-
-                public void WriteTo(pb::CodedOutputStream output)
-                {
-                    if (Provider.Length != 0)
-                    {
-                        output.WriteRawTag(10);
-                        output.WriteString(Provider);
-                    }
-                    if (token_ != null)
-                    {
-                        output.WriteRawTag(18);
-                        output.WriteMessage(Token);
-                    }
-                }
-
-                public int CalculateSize()
-                {
-                    var size = 0;
-                    if (Provider.Length != 0)
-                    {
-                        size += 1 + pb::CodedOutputStream.ComputeStringSize(Provider);
-                    }
-                    if (token_ != null)
-                    {
-                        size += 1 + pb::CodedOutputStream.ComputeMessageSize(Token);
-                    }
-                    return size;
-                }
-
-                public void MergeFrom(AuthInfo other)
-                {
-                    if (other == null)
-                    {
-                        return;
-                    }
-                    if (other.Provider.Length != 0)
-                    {
-                        Provider = other.Provider;
-                    }
-                    if (other.token_ != null)
-                    {
-                        if (token_ == null)
-                        {
-                            token_ = new global::PokemonGo.RocketAPI.GeneratedCode.Request.Types.AuthInfo.Types.JWT();
-                        }
-                        Token.MergeFrom(other.Token);
-                    }
-                }
-
-                public void MergeFrom(pb::CodedInputStream input)
-                {
-                    uint tag;
-                    while ((tag = input.ReadTag()) != 0)
-                    {
-                        switch (tag)
-                        {
-                            default:
-                                input.SkipLastField();
-                                break;
-                            case 10:
-                            {
-                                Provider = input.ReadString();
-                                break;
-                            }
-                            case 18:
-                            {
-                                if (token_ == null)
-                                {
-                                    token_ =
-                                        new global::PokemonGo.RocketAPI.GeneratedCode.Request.Types.AuthInfo.Types.JWT();
-                                }
-                                input.ReadMessage(token_);
-                                break;
-                            }
-                        }
-                    }
-                }
-
-                public override bool Equals(object other)
-                {
-                    return Equals(other as AuthInfo);
-                }
-
-                public override int GetHashCode()
-                {
-                    var hash = 1;
-                    if (Provider.Length != 0) hash ^= Provider.GetHashCode();
-                    if (token_ != null) hash ^= Token.GetHashCode();
-                    return hash;
-                }
-
-                partial void OnConstruction();
-
-                public override string ToString()
-                {
-                    return pb::JsonFormatter.ToDiagnosticString(this);
-                }
-
-                #region Nested types
-
-                /// <summary>Container for nested types declared in the AuthInfo message type.</summary>
-                [global::System.Diagnostics.DebuggerNonUserCodeAttribute()]
-                public static partial class Types
-                {
-                    [global::System.Diagnostics.DebuggerNonUserCodeAttribute()]
-                    public sealed partial class JWT : pb::IMessage<JWT>
-                    {
-                        /// <summary>Field number for the "contents" field.</summary>
-                        public const int ContentsFieldNumber = 1;
-
-                        /// <summary>Field number for the "unknown13" field.</summary>
-                        public const int Unknown13FieldNumber = 2;
-
-                        private static readonly pb::MessageParser<JWT> _parser =
-                            new pb::MessageParser<JWT>(() => new JWT());
-
-                        private string contents_ = "";
-                        private int unknown13_;
-
-                        public JWT()
-                        {
-                            OnConstruction();
-                        }
-
-                        public JWT(JWT other) : this()
-                        {
-                            contents_ = other.contents_;
-                            unknown13_ = other.unknown13_;
-                        }
-
-                        public static pb::MessageParser<JWT> Parser
-                        {
-                            get { return _parser; }
-                        }
-
-                        public static pbr::MessageDescriptor Descriptor
-                        {
-                            get
-                            {
-                                return
-                                    global::PokemonGo.RocketAPI.GeneratedCode.Request.Types.AuthInfo.Descriptor
-                                        .NestedTypes[0];
-                            }
-                        }
-
-                        public string Contents
-                        {
-                            get { return contents_; }
-                            set { contents_ = pb::ProtoPreconditions.CheckNotNull(value, "value"); }
-                        }
-
-                        public int Unknown13
-                        {
-                            get { return unknown13_; }
-                            set { unknown13_ = value; }
-                        }
-
-                        pbr::MessageDescriptor pb::IMessage.Descriptor
-                        {
-                            get { return Descriptor; }
-                        }
-
-                        public JWT Clone()
-                        {
-                            return new JWT(this);
-                        }
-
-                        public bool Equals(JWT other)
-                        {
-                            if (ReferenceEquals(other, null))
-                            {
-                                return false;
-                            }
-                            if (ReferenceEquals(other, this))
-                            {
-                                return true;
-                            }
-                            if (Contents != other.Contents) return false;
-                            if (Unknown13 != other.Unknown13) return false;
-                            return true;
-                        }
-
-                        public void WriteTo(pb::CodedOutputStream output)
-                        {
-                            if (Contents.Length != 0)
-                            {
-                                output.WriteRawTag(10);
-                                output.WriteString(Contents);
-                            }
-                            if (Unknown13 != 0)
-                            {
-                                output.WriteRawTag(16);
-                                output.WriteInt32(Unknown13);
-                            }
-                        }
-
-                        public int CalculateSize()
-                        {
-                            var size = 0;
-                            if (Contents.Length != 0)
-                            {
-                                size += 1 + pb::CodedOutputStream.ComputeStringSize(Contents);
-                            }
-                            if (Unknown13 != 0)
-                            {
-                                size += 1 + pb::CodedOutputStream.ComputeInt32Size(Unknown13);
-                            }
-                            return size;
-                        }
-
-                        public void MergeFrom(JWT other)
-                        {
-                            if (other == null)
-                            {
-                                return;
-                            }
-                            if (other.Contents.Length != 0)
-                            {
-                                Contents = other.Contents;
-                            }
-                            if (other.Unknown13 != 0)
-                            {
-                                Unknown13 = other.Unknown13;
-                            }
-                        }
-
-                        public void MergeFrom(pb::CodedInputStream input)
-                        {
-                            uint tag;
-                            while ((tag = input.ReadTag()) != 0)
-                            {
-                                switch (tag)
-                                {
-                                    default:
-                                        input.SkipLastField();
-                                        break;
-                                    case 10:
-                                    {
-                                        Contents = input.ReadString();
-                                        break;
-                                    }
-                                    case 16:
-                                    {
-                                        Unknown13 = input.ReadInt32();
-                                        break;
-                                    }
-                                }
-                            }
-                        }
-
-                        public override bool Equals(object other)
-                        {
-                            return Equals(other as JWT);
-                        }
-
-                        public override int GetHashCode()
-                        {
-                            var hash = 1;
-                            if (Contents.Length != 0) hash ^= Contents.GetHashCode();
-                            if (Unknown13 != 0) hash ^= Unknown13.GetHashCode();
-                            return hash;
-                        }
-
-                        partial void OnConstruction();
-
-                        public override string ToString()
-                        {
-                            return pb::JsonFormatter.ToDiagnosticString(this);
-                        }
-                    }
-                }
-
-                #endregion
-            }
-
-            [global::System.Diagnostics.DebuggerNonUserCodeAttribute()]
-            public sealed partial class PlayerUpdateProto : pb::IMessage<PlayerUpdateProto>
-            {
-                /// <summary>Field number for the "Lat" field.</summary>
-                public const int LatFieldNumber = 1;
-
-                /// <summary>Field number for the "Lng" field.</summary>
-                public const int LngFieldNumber = 2;
-
-                private static readonly pb::MessageParser<PlayerUpdateProto> _parser =
-                    new pb::MessageParser<PlayerUpdateProto>(() => new PlayerUpdateProto());
-
-                private ulong lat_;
-                private ulong lng_;
-
-                public PlayerUpdateProto()
-                {
-                    OnConstruction();
-                }
-
-                public PlayerUpdateProto(PlayerUpdateProto other) : this()
-                {
-                    lat_ = other.lat_;
-                    lng_ = other.lng_;
-                }
-
-                public static pb::MessageParser<PlayerUpdateProto> Parser
-                {
-                    get { return _parser; }
-                }
-
-                public static pbr::MessageDescriptor Descriptor
-                {
-                    get { return global::PokemonGo.RocketAPI.GeneratedCode.Request.Descriptor.NestedTypes[5]; }
-                }
-
-                public ulong Lat
-                {
-                    get { return lat_; }
-                    set { lat_ = value; }
-                }
-
-                public ulong Lng
-                {
-                    get { return lng_; }
-                    set { lng_ = value; }
-                }
-
-                pbr::MessageDescriptor pb::IMessage.Descriptor
-                {
-                    get { return Descriptor; }
-                }
-
-                public PlayerUpdateProto Clone()
-                {
-                    return new PlayerUpdateProto(this);
-                }
-
-                public bool Equals(PlayerUpdateProto other)
-                {
-                    if (ReferenceEquals(other, null))
-                    {
-                        return false;
-                    }
-                    if (ReferenceEquals(other, this))
-                    {
-                        return true;
-                    }
-                    if (Lat != other.Lat) return false;
-                    if (Lng != other.Lng) return false;
-                    return true;
-                }
-
-                public void WriteTo(pb::CodedOutputStream output)
-                {
-                    if (Lat != 0UL)
-                    {
-                        output.WriteRawTag(9);
-                        output.WriteFixed64(Lat);
-                    }
-                    if (Lng != 0UL)
-                    {
-                        output.WriteRawTag(17);
-                        output.WriteFixed64(Lng);
-                    }
-                }
-
-                public int CalculateSize()
-                {
-                    var size = 0;
-                    if (Lat != 0UL)
-                    {
-                        size += 1 + 8;
-                    }
-                    if (Lng != 0UL)
-                    {
-                        size += 1 + 8;
-                    }
-                    return size;
-                }
-
-                public void MergeFrom(PlayerUpdateProto other)
-                {
-                    if (other == null)
-                    {
-                        return;
-                    }
-                    if (other.Lat != 0UL)
-                    {
-                        Lat = other.Lat;
-                    }
-                    if (other.Lng != 0UL)
-                    {
-                        Lng = other.Lng;
-                    }
-                }
-
-                public void MergeFrom(pb::CodedInputStream input)
-                {
-                    uint tag;
-                    while ((tag = input.ReadTag()) != 0)
-                    {
-                        switch (tag)
-                        {
-                            default:
-                                input.SkipLastField();
-                                break;
-                            case 9:
-                            {
-                                Lat = input.ReadFixed64();
-                                break;
-                            }
-                            case 17:
-                            {
-                                Lng = input.ReadFixed64();
-                                break;
-                            }
-                        }
-                    }
-                }
-
-                public override bool Equals(object other)
-                {
-                    return Equals(other as PlayerUpdateProto);
-                }
-
-                public override int GetHashCode()
-                {
-                    var hash = 1;
-                    if (Lat != 0UL) hash ^= Lat.GetHashCode();
-                    if (Lng != 0UL) hash ^= Lng.GetHashCode();
-                    return hash;
-                }
-
-                partial void OnConstruction();
-
-                public override string ToString()
-                {
-                    return pb::JsonFormatter.ToDiagnosticString(this);
-                }
-            }
-
-            [global::System.Diagnostics.DebuggerNonUserCodeAttribute()]
-            public sealed partial class MapObjectsRequest : pb::IMessage<MapObjectsRequest>
-            {
-                /// <summary>Field number for the "cellIds" field.</summary>
-                public const int CellIdsFieldNumber = 1;
-
-                /// <summary>Field number for the "unknown14" field.</summary>
-                public const int Unknown14FieldNumber = 2;
-
-                /// <summary>Field number for the "latitude" field.</summary>
-                public const int LatitudeFieldNumber = 3;
-
-                /// <summary>Field number for the "longitude" field.</summary>
-                public const int LongitudeFieldNumber = 4;
-
-                private static readonly pb::MessageParser<MapObjectsRequest> _parser =
-                    new pb::MessageParser<MapObjectsRequest>(() => new MapObjectsRequest());
-
-                private pb::ByteString cellIds_ = pb::ByteString.Empty;
-                private ulong latitude_;
-                private ulong longitude_;
-                private pb::ByteString unknown14_ = pb::ByteString.Empty;
-
-                public MapObjectsRequest()
-                {
-                    OnConstruction();
-                }
-
-                public MapObjectsRequest(MapObjectsRequest other) : this()
-                {
-                    cellIds_ = other.cellIds_;
-                    unknown14_ = other.unknown14_;
-                    latitude_ = other.latitude_;
-                    longitude_ = other.longitude_;
-                }
-
-                public static pb::MessageParser<MapObjectsRequest> Parser
-                {
-                    get { return _parser; }
-                }
-
-                public static pbr::MessageDescriptor Descriptor
-                {
-                    get { return global::PokemonGo.RocketAPI.GeneratedCode.Request.Descriptor.NestedTypes[6]; }
-                }
-
-                public pb::ByteString CellIds
-                {
-                    get { return cellIds_; }
-                    set { cellIds_ = pb::ProtoPreconditions.CheckNotNull(value, "value"); }
-                }
-
-                public pb::ByteString Unknown14
-                {
-                    get { return unknown14_; }
-                    set { unknown14_ = pb::ProtoPreconditions.CheckNotNull(value, "value"); }
-                }
-
-                public ulong Latitude
-                {
-                    get { return latitude_; }
-                    set { latitude_ = value; }
-                }
-
-                public ulong Longitude
-                {
-                    get { return longitude_; }
-                    set { longitude_ = value; }
-                }
-
-                pbr::MessageDescriptor pb::IMessage.Descriptor
-                {
-                    get { return Descriptor; }
-                }
-
-                public MapObjectsRequest Clone()
-                {
-                    return new MapObjectsRequest(this);
-                }
-
-                public bool Equals(MapObjectsRequest other)
-                {
-                    if (ReferenceEquals(other, null))
-                    {
-                        return false;
-                    }
-                    if (ReferenceEquals(other, this))
-                    {
-                        return true;
-                    }
-                    if (CellIds != other.CellIds) return false;
-                    if (Unknown14 != other.Unknown14) return false;
-                    if (Latitude != other.Latitude) return false;
-                    if (Longitude != other.Longitude) return false;
-                    return true;
-                }
-
-                public void WriteTo(pb::CodedOutputStream output)
-                {
-                    if (CellIds.Length != 0)
-                    {
-                        output.WriteRawTag(10);
-                        output.WriteBytes(CellIds);
-                    }
-                    if (Unknown14.Length != 0)
-                    {
-                        output.WriteRawTag(18);
-                        output.WriteBytes(Unknown14);
-                    }
-                    if (Latitude != 0UL)
-                    {
-                        output.WriteRawTag(25);
-                        output.WriteFixed64(Latitude);
-                    }
-                    if (Longitude != 0UL)
-                    {
-                        output.WriteRawTag(33);
-                        output.WriteFixed64(Longitude);
-                    }
-                }
-
-                public int CalculateSize()
-                {
-                    var size = 0;
-                    if (CellIds.Length != 0)
-                    {
-                        size += 1 + pb::CodedOutputStream.ComputeBytesSize(CellIds);
-                    }
-                    if (Unknown14.Length != 0)
-                    {
-                        size += 1 + pb::CodedOutputStream.ComputeBytesSize(Unknown14);
-                    }
-                    if (Latitude != 0UL)
-                    {
-                        size += 1 + 8;
-                    }
-                    if (Longitude != 0UL)
-                    {
-                        size += 1 + 8;
-                    }
-                    return size;
-                }
-
-                public void MergeFrom(MapObjectsRequest other)
-                {
-                    if (other == null)
-                    {
-                        return;
-                    }
-                    if (other.CellIds.Length != 0)
-                    {
-                        CellIds = other.CellIds;
-                    }
-                    if (other.Unknown14.Length != 0)
-                    {
-                        Unknown14 = other.Unknown14;
-                    }
-                    if (other.Latitude != 0UL)
-                    {
-                        Latitude = other.Latitude;
-                    }
-                    if (other.Longitude != 0UL)
-                    {
-                        Longitude = other.Longitude;
-                    }
-                }
-
-                public void MergeFrom(pb::CodedInputStream input)
-                {
-                    uint tag;
-                    while ((tag = input.ReadTag()) != 0)
-                    {
-                        switch (tag)
-                        {
-                            default:
-                                input.SkipLastField();
-                                break;
-                            case 10:
-                            {
-                                CellIds = input.ReadBytes();
-                                break;
-                            }
-                            case 18:
-                            {
-                                Unknown14 = input.ReadBytes();
-                                break;
-                            }
-                            case 25:
-                            {
-                                Latitude = input.ReadFixed64();
-                                break;
-                            }
-                            case 33:
-                            {
-                                Longitude = input.ReadFixed64();
-                                break;
-                            }
-                        }
-                    }
-                }
-
-                public override bool Equals(object other)
-                {
-                    return Equals(other as MapObjectsRequest);
-                }
-
-                public override int GetHashCode()
-                {
-                    var hash = 1;
-                    if (CellIds.Length != 0) hash ^= CellIds.GetHashCode();
-                    if (Unknown14.Length != 0) hash ^= Unknown14.GetHashCode();
-                    if (Latitude != 0UL) hash ^= Latitude.GetHashCode();
-                    if (Longitude != 0UL) hash ^= Longitude.GetHashCode();
-                    return hash;
-                }
-
-                partial void OnConstruction();
-
-                public override string ToString()
-                {
-                    return pb::JsonFormatter.ToDiagnosticString(this);
-                }
-            }
-
-            [global::System.Diagnostics.DebuggerNonUserCodeAttribute()]
-            public sealed partial class FortSearchRequest : pb::IMessage<FortSearchRequest>
-            {
-                /// <summary>Field number for the "Id" field.</summary>
-                public const int IdFieldNumber = 1;
-
-                /// <summary>Field number for the "PlayerLatDegrees" field.</summary>
-                public const int PlayerLatDegreesFieldNumber = 2;
-
-                /// <summary>Field number for the "PlayerLngDegrees" field.</summary>
-                public const int PlayerLngDegreesFieldNumber = 3;
-
-                /// <summary>Field number for the "FortLatDegrees" field.</summary>
-                public const int FortLatDegreesFieldNumber = 4;
-
-                /// <summary>Field number for the "FortLngDegrees" field.</summary>
-                public const int FortLngDegreesFieldNumber = 5;
-
-                private static readonly pb::MessageParser<FortSearchRequest> _parser =
-                    new pb::MessageParser<FortSearchRequest>(() => new FortSearchRequest());
-
-                private ulong fortLatDegrees_;
-                private ulong fortLngDegrees_;
-                private pb::ByteString id_ = pb::ByteString.Empty;
-                private ulong playerLatDegrees_;
-                private ulong playerLngDegrees_;
-
-                public FortSearchRequest()
-                {
-                    OnConstruction();
-                }
-
-                public FortSearchRequest(FortSearchRequest other) : this()
-                {
-                    id_ = other.id_;
-                    playerLatDegrees_ = other.playerLatDegrees_;
-                    playerLngDegrees_ = other.playerLngDegrees_;
-                    fortLatDegrees_ = other.fortLatDegrees_;
-                    fortLngDegrees_ = other.fortLngDegrees_;
-                }
-
-                public static pb::MessageParser<FortSearchRequest> Parser
-                {
-                    get { return _parser; }
-                }
-
-                public static pbr::MessageDescriptor Descriptor
-                {
-                    get { return global::PokemonGo.RocketAPI.GeneratedCode.Request.Descriptor.NestedTypes[7]; }
-                }
-
-                public pb::ByteString Id
-                {
-                    get { return id_; }
-                    set { id_ = pb::ProtoPreconditions.CheckNotNull(value, "value"); }
-                }
-
-                public ulong PlayerLatDegrees
-                {
-                    get { return playerLatDegrees_; }
-                    set { playerLatDegrees_ = value; }
-                }
-
-                public ulong PlayerLngDegrees
-                {
-                    get { return playerLngDegrees_; }
-                    set { playerLngDegrees_ = value; }
-                }
-
-                public ulong FortLatDegrees
-                {
-                    get { return fortLatDegrees_; }
-                    set { fortLatDegrees_ = value; }
-                }
-
-                public ulong FortLngDegrees
-                {
-                    get { return fortLngDegrees_; }
-                    set { fortLngDegrees_ = value; }
-                }
-
-                pbr::MessageDescriptor pb::IMessage.Descriptor
-                {
-                    get { return Descriptor; }
-                }
-
-                public FortSearchRequest Clone()
-                {
-                    return new FortSearchRequest(this);
-                }
-
-                public bool Equals(FortSearchRequest other)
-                {
-                    if (ReferenceEquals(other, null))
-                    {
-                        return false;
-                    }
-                    if (ReferenceEquals(other, this))
-                    {
-                        return true;
-                    }
-                    if (Id != other.Id) return false;
-                    if (PlayerLatDegrees != other.PlayerLatDegrees) return false;
-                    if (PlayerLngDegrees != other.PlayerLngDegrees) return false;
-                    if (FortLatDegrees != other.FortLatDegrees) return false;
-                    if (FortLngDegrees != other.FortLngDegrees) return false;
-                    return true;
-                }
-
-                public void WriteTo(pb::CodedOutputStream output)
-                {
-                    if (Id.Length != 0)
-                    {
-                        output.WriteRawTag(10);
-                        output.WriteBytes(Id);
-                    }
-                    if (PlayerLatDegrees != 0UL)
-                    {
-                        output.WriteRawTag(17);
-                        output.WriteFixed64(PlayerLatDegrees);
-                    }
-                    if (PlayerLngDegrees != 0UL)
-                    {
-                        output.WriteRawTag(25);
-                        output.WriteFixed64(PlayerLngDegrees);
-                    }
-                    if (FortLatDegrees != 0UL)
-                    {
-                        output.WriteRawTag(33);
-                        output.WriteFixed64(FortLatDegrees);
-                    }
-                    if (FortLngDegrees != 0UL)
-                    {
-                        output.WriteRawTag(41);
-                        output.WriteFixed64(FortLngDegrees);
-                    }
-                }
-
-                public int CalculateSize()
-                {
-                    var size = 0;
-                    if (Id.Length != 0)
-                    {
-                        size += 1 + pb::CodedOutputStream.ComputeBytesSize(Id);
-                    }
-                    if (PlayerLatDegrees != 0UL)
-                    {
-                        size += 1 + 8;
-                    }
-                    if (PlayerLngDegrees != 0UL)
-                    {
-                        size += 1 + 8;
-                    }
-                    if (FortLatDegrees != 0UL)
-                    {
-                        size += 1 + 8;
-                    }
-                    if (FortLngDegrees != 0UL)
-                    {
-                        size += 1 + 8;
-                    }
-                    return size;
-                }
-
-                public void MergeFrom(FortSearchRequest other)
-                {
-                    if (other == null)
-                    {
-                        return;
-                    }
-                    if (other.Id.Length != 0)
-                    {
-                        Id = other.Id;
-                    }
-                    if (other.PlayerLatDegrees != 0UL)
-                    {
-                        PlayerLatDegrees = other.PlayerLatDegrees;
-                    }
-                    if (other.PlayerLngDegrees != 0UL)
-                    {
-                        PlayerLngDegrees = other.PlayerLngDegrees;
-                    }
-                    if (other.FortLatDegrees != 0UL)
-                    {
-                        FortLatDegrees = other.FortLatDegrees;
-                    }
-                    if (other.FortLngDegrees != 0UL)
-                    {
-                        FortLngDegrees = other.FortLngDegrees;
-                    }
-                }
-
-                public void MergeFrom(pb::CodedInputStream input)
-                {
-                    uint tag;
-                    while ((tag = input.ReadTag()) != 0)
-                    {
-                        switch (tag)
-                        {
-                            default:
-                                input.SkipLastField();
-                                break;
-                            case 10:
-                            {
-                                Id = input.ReadBytes();
-                                break;
-                            }
-                            case 17:
-                            {
-                                PlayerLatDegrees = input.ReadFixed64();
-                                break;
-                            }
-                            case 25:
-                            {
-                                PlayerLngDegrees = input.ReadFixed64();
-                                break;
-                            }
-                            case 33:
-                            {
-                                FortLatDegrees = input.ReadFixed64();
-                                break;
-                            }
-                            case 41:
-                            {
-                                FortLngDegrees = input.ReadFixed64();
-                                break;
-                            }
-                        }
-                    }
-                }
-
-                public override bool Equals(object other)
-                {
-                    return Equals(other as FortSearchRequest);
-                }
-
-                public override int GetHashCode()
-                {
-                    var hash = 1;
-                    if (Id.Length != 0) hash ^= Id.GetHashCode();
-                    if (PlayerLatDegrees != 0UL) hash ^= PlayerLatDegrees.GetHashCode();
-                    if (PlayerLngDegrees != 0UL) hash ^= PlayerLngDegrees.GetHashCode();
-                    if (FortLatDegrees != 0UL) hash ^= FortLatDegrees.GetHashCode();
-                    if (FortLngDegrees != 0UL) hash ^= FortLngDegrees.GetHashCode();
-                    return hash;
-                }
-
-                partial void OnConstruction();
-
-                public override string ToString()
-                {
-                    return pb::JsonFormatter.ToDiagnosticString(this);
-                }
-            }
-
-            [global::System.Diagnostics.DebuggerNonUserCodeAttribute()]
-            public sealed partial class FortDetailsRequest : pb::IMessage<FortDetailsRequest>
-            {
-                /// <summary>Field number for the "Id" field.</summary>
-                public const int IdFieldNumber = 1;
-
-                /// <summary>Field number for the "Latitude" field.</summary>
-                public const int LatitudeFieldNumber = 2;
-
-                /// <summary>Field number for the "Longitude" field.</summary>
-                public const int LongitudeFieldNumber = 3;
-
-                private static readonly pb::MessageParser<FortDetailsRequest> _parser =
-                    new pb::MessageParser<FortDetailsRequest>(() => new FortDetailsRequest());
-
-                private pb::ByteString id_ = pb::ByteString.Empty;
-                private ulong latitude_;
-                private ulong longitude_;
-
-                public FortDetailsRequest()
-                {
-                    OnConstruction();
-                }
-
-                public FortDetailsRequest(FortDetailsRequest other) : this()
-                {
-                    id_ = other.id_;
-                    latitude_ = other.latitude_;
-                    longitude_ = other.longitude_;
-                }
-
-                public static pb::MessageParser<FortDetailsRequest> Parser
-                {
-                    get { return _parser; }
-                }
-
-                public static pbr::MessageDescriptor Descriptor
-                {
-                    get { return global::PokemonGo.RocketAPI.GeneratedCode.Request.Descriptor.NestedTypes[8]; }
-                }
-
-                public pb::ByteString Id
-                {
-                    get { return id_; }
-                    set { id_ = pb::ProtoPreconditions.CheckNotNull(value, "value"); }
-                }
-
-                public ulong Latitude
-                {
-                    get { return latitude_; }
-                    set { latitude_ = value; }
-                }
-
-                public ulong Longitude
-                {
-                    get { return longitude_; }
-                    set { longitude_ = value; }
-                }
-
-                pbr::MessageDescriptor pb::IMessage.Descriptor
-                {
-                    get { return Descriptor; }
-                }
-
-                public FortDetailsRequest Clone()
-                {
-                    return new FortDetailsRequest(this);
-                }
-
-                public bool Equals(FortDetailsRequest other)
-                {
-                    if (ReferenceEquals(other, null))
-                    {
-                        return false;
-                    }
-                    if (ReferenceEquals(other, this))
-                    {
-                        return true;
-                    }
-                    if (Id != other.Id) return false;
-                    if (Latitude != other.Latitude) return false;
-                    if (Longitude != other.Longitude) return false;
-                    return true;
-                }
-
-                public void WriteTo(pb::CodedOutputStream output)
-                {
-                    if (Id.Length != 0)
-                    {
-                        output.WriteRawTag(10);
-                        output.WriteBytes(Id);
-                    }
-                    if (Latitude != 0UL)
-                    {
-                        output.WriteRawTag(17);
-                        output.WriteFixed64(Latitude);
-                    }
-                    if (Longitude != 0UL)
-                    {
-                        output.WriteRawTag(25);
-                        output.WriteFixed64(Longitude);
-                    }
-                }
-
-                public int CalculateSize()
-                {
-                    var size = 0;
-                    if (Id.Length != 0)
-                    {
-                        size += 1 + pb::CodedOutputStream.ComputeBytesSize(Id);
-                    }
-                    if (Latitude != 0UL)
-                    {
-                        size += 1 + 8;
-                    }
-                    if (Longitude != 0UL)
-                    {
-                        size += 1 + 8;
-                    }
-                    return size;
-                }
-
-                public void MergeFrom(FortDetailsRequest other)
-                {
-                    if (other == null)
-                    {
-                        return;
-                    }
-                    if (other.Id.Length != 0)
-                    {
-                        Id = other.Id;
-                    }
-                    if (other.Latitude != 0UL)
-                    {
-                        Latitude = other.Latitude;
-                    }
-                    if (other.Longitude != 0UL)
-                    {
-                        Longitude = other.Longitude;
-                    }
-                }
-
-                public void MergeFrom(pb::CodedInputStream input)
-                {
-                    uint tag;
-                    while ((tag = input.ReadTag()) != 0)
-                    {
-                        switch (tag)
-                        {
-                            default:
-                                input.SkipLastField();
-                                break;
-                            case 10:
-                            {
-                                Id = input.ReadBytes();
-                                break;
-                            }
-                            case 17:
-                            {
-                                Latitude = input.ReadFixed64();
-                                break;
-                            }
-                            case 25:
-                            {
-                                Longitude = input.ReadFixed64();
-                                break;
-                            }
-                        }
-                    }
-                }
-
-                public override bool Equals(object other)
-                {
-                    return Equals(other as FortDetailsRequest);
-                }
-
-                public override int GetHashCode()
-                {
-                    var hash = 1;
-                    if (Id.Length != 0) hash ^= Id.GetHashCode();
-                    if (Latitude != 0UL) hash ^= Latitude.GetHashCode();
-                    if (Longitude != 0UL) hash ^= Longitude.GetHashCode();
-                    return hash;
-                }
-
-                partial void OnConstruction();
-
-                public override string ToString()
-                {
-                    return pb::JsonFormatter.ToDiagnosticString(this);
-                }
-            }
-
-            [global::System.Diagnostics.DebuggerNonUserCodeAttribute()]
-            public sealed partial class EncounterRequest : pb::IMessage<EncounterRequest>
-            {
-                /// <summary>Field number for the "EncounterId" field.</summary>
-                public const int EncounterIdFieldNumber = 1;
-
-                /// <summary>Field number for the "SpawnpointId" field.</summary>
-                public const int SpawnpointIdFieldNumber = 2;
-
-                /// <summary>Field number for the "PlayerLatDegrees" field.</summary>
-                public const int PlayerLatDegreesFieldNumber = 3;
-
-                /// <summary>Field number for the "PlayerLngDegrees" field.</summary>
-                public const int PlayerLngDegreesFieldNumber = 4;
-
-                private static readonly pb::MessageParser<EncounterRequest> _parser =
-                    new pb::MessageParser<EncounterRequest>(() => new EncounterRequest());
-
-                private ulong encounterId_;
-                private ulong playerLatDegrees_;
-                private ulong playerLngDegrees_;
-                private string spawnpointId_ = "";
-
-                public EncounterRequest()
-                {
-                    OnConstruction();
-                }
-
-                public EncounterRequest(EncounterRequest other) : this()
-                {
-                    encounterId_ = other.encounterId_;
-                    spawnpointId_ = other.spawnpointId_;
-                    playerLatDegrees_ = other.playerLatDegrees_;
-                    playerLngDegrees_ = other.playerLngDegrees_;
-                }
-
-                public static pb::MessageParser<EncounterRequest> Parser
-                {
-                    get { return _parser; }
-                }
-
-                public static pbr::MessageDescriptor Descriptor
-                {
-                    get { return global::PokemonGo.RocketAPI.GeneratedCode.Request.Descriptor.NestedTypes[9]; }
-                }
-
-                public ulong EncounterId
-                {
-                    get { return encounterId_; }
-                    set { encounterId_ = value; }
-                }
-
-                public string SpawnpointId
-                {
-                    get { return spawnpointId_; }
-                    set { spawnpointId_ = pb::ProtoPreconditions.CheckNotNull(value, "value"); }
-                }
-
-                public ulong PlayerLatDegrees
-                {
-                    get { return playerLatDegrees_; }
-                    set { playerLatDegrees_ = value; }
-                }
-
-                public ulong PlayerLngDegrees
-                {
-                    get { return playerLngDegrees_; }
-                    set { playerLngDegrees_ = value; }
-                }
-
-                pbr::MessageDescriptor pb::IMessage.Descriptor
-                {
-                    get { return Descriptor; }
-                }
-
-                public EncounterRequest Clone()
-                {
-                    return new EncounterRequest(this);
-                }
-
-                public bool Equals(EncounterRequest other)
-                {
-                    if (ReferenceEquals(other, null))
-                    {
-                        return false;
-                    }
-                    if (ReferenceEquals(other, this))
-                    {
-                        return true;
-                    }
-                    if (EncounterId != other.EncounterId) return false;
-                    if (SpawnpointId != other.SpawnpointId) return false;
-                    if (PlayerLatDegrees != other.PlayerLatDegrees) return false;
-                    if (PlayerLngDegrees != other.PlayerLngDegrees) return false;
-                    return true;
-                }
-
-                public void WriteTo(pb::CodedOutputStream output)
-                {
-                    if (EncounterId != 0UL)
-                    {
-                        output.WriteRawTag(9);
-                        output.WriteFixed64(EncounterId);
-                    }
-                    if (SpawnpointId.Length != 0)
-                    {
-                        output.WriteRawTag(18);
-                        output.WriteString(SpawnpointId);
-                    }
-                    if (PlayerLatDegrees != 0UL)
-                    {
-                        output.WriteRawTag(25);
-                        output.WriteFixed64(PlayerLatDegrees);
-                    }
-                    if (PlayerLngDegrees != 0UL)
-                    {
-                        output.WriteRawTag(33);
-                        output.WriteFixed64(PlayerLngDegrees);
-                    }
-                }
-
-                public int CalculateSize()
-                {
-                    var size = 0;
-                    if (EncounterId != 0UL)
-                    {
-                        size += 1 + 8;
-                    }
-                    if (SpawnpointId.Length != 0)
-                    {
-                        size += 1 + pb::CodedOutputStream.ComputeStringSize(SpawnpointId);
-                    }
-                    if (PlayerLatDegrees != 0UL)
-                    {
-                        size += 1 + 8;
-                    }
-                    if (PlayerLngDegrees != 0UL)
-                    {
-                        size += 1 + 8;
-                    }
-                    return size;
-                }
-
-                public void MergeFrom(EncounterRequest other)
-                {
-                    if (other == null)
-                    {
-                        return;
-                    }
-                    if (other.EncounterId != 0UL)
-                    {
-                        EncounterId = other.EncounterId;
-                    }
-                    if (other.SpawnpointId.Length != 0)
-                    {
-                        SpawnpointId = other.SpawnpointId;
-                    }
-                    if (other.PlayerLatDegrees != 0UL)
-                    {
-                        PlayerLatDegrees = other.PlayerLatDegrees;
-                    }
-                    if (other.PlayerLngDegrees != 0UL)
-                    {
-                        PlayerLngDegrees = other.PlayerLngDegrees;
-                    }
-                }
-
-                public void MergeFrom(pb::CodedInputStream input)
-                {
-                    uint tag;
-                    while ((tag = input.ReadTag()) != 0)
-                    {
-                        switch (tag)
-                        {
-                            default:
-                                input.SkipLastField();
-                                break;
-                            case 9:
-                            {
-                                EncounterId = input.ReadFixed64();
-                                break;
-                            }
-                            case 18:
-                            {
-                                SpawnpointId = input.ReadString();
-                                break;
-                            }
-                            case 25:
-                            {
-                                PlayerLatDegrees = input.ReadFixed64();
-                                break;
-                            }
-                            case 33:
-                            {
-                                PlayerLngDegrees = input.ReadFixed64();
-                                break;
-                            }
-                        }
-                    }
-                }
-
-                public override bool Equals(object other)
-                {
-                    return Equals(other as EncounterRequest);
-                }
-
-                public override int GetHashCode()
-                {
-                    var hash = 1;
-                    if (EncounterId != 0UL) hash ^= EncounterId.GetHashCode();
-                    if (SpawnpointId.Length != 0) hash ^= SpawnpointId.GetHashCode();
-                    if (PlayerLatDegrees != 0UL) hash ^= PlayerLatDegrees.GetHashCode();
-                    if (PlayerLngDegrees != 0UL) hash ^= PlayerLngDegrees.GetHashCode();
-                    return hash;
-                }
-
-                partial void OnConstruction();
-
-                public override string ToString()
-                {
-                    return pb::JsonFormatter.ToDiagnosticString(this);
-                }
-            }
-
-            [global::System.Diagnostics.DebuggerNonUserCodeAttribute()]
-            public sealed partial class CatchPokemonRequest : pb::IMessage<CatchPokemonRequest>
-            {
-                /// <summary>Field number for the "EncounterId" field.</summary>
-                public const int EncounterIdFieldNumber = 1;
-
-                /// <summary>Field number for the "Pokeball" field.</summary>
-                public const int PokeballFieldNumber = 2;
-
-                /// <summary>Field number for the "NormalizedReticleSize" field.</summary>
-                public const int NormalizedReticleSizeFieldNumber = 3;
-
-                /// <summary>Field number for the "SpawnPointGuid" field.</summary>
-                public const int SpawnPointGuidFieldNumber = 4;
-
-                /// <summary>Field number for the "HitPokemon" field.</summary>
-                public const int HitPokemonFieldNumber = 5;
-
-                /// <summary>Field number for the "SpinModifier" field.</summary>
-                public const int SpinModifierFieldNumber = 6;
-
-                /// <summary>Field number for the "NormalizedHitPosition" field.</summary>
-                public const int NormalizedHitPositionFieldNumber = 7;
-
-                private static readonly pb::MessageParser<CatchPokemonRequest> _parser =
-                    new pb::MessageParser<CatchPokemonRequest>(() => new CatchPokemonRequest());
-
-                private ulong encounterId_;
-                private int hitPokemon_;
-                private ulong normalizedHitPosition_;
-                private ulong normalizedReticleSize_;
-                private int pokeball_;
-                private string spawnPointGuid_ = "";
-                private ulong spinModifier_;
-
-                public CatchPokemonRequest()
-                {
-                    OnConstruction();
-                }
-
-                public CatchPokemonRequest(CatchPokemonRequest other) : this()
-                {
-                    encounterId_ = other.encounterId_;
-                    pokeball_ = other.pokeball_;
-                    normalizedReticleSize_ = other.normalizedReticleSize_;
-                    spawnPointGuid_ = other.spawnPointGuid_;
-                    hitPokemon_ = other.hitPokemon_;
-                    spinModifier_ = other.spinModifier_;
-                    normalizedHitPosition_ = other.normalizedHitPosition_;
-                }
-
-                public static pb::MessageParser<CatchPokemonRequest> Parser
-                {
-                    get { return _parser; }
-                }
-
-                public static pbr::MessageDescriptor Descriptor
-                {
-                    get { return global::PokemonGo.RocketAPI.GeneratedCode.Request.Descriptor.NestedTypes[10]; }
-                }
-
-                public ulong EncounterId
-                {
-                    get { return encounterId_; }
-                    set { encounterId_ = value; }
-                }
-
-                public int Pokeball
-                {
-                    get { return pokeball_; }
-                    set { pokeball_ = value; }
-                }
-
-                public ulong NormalizedReticleSize
-                {
-                    get { return normalizedReticleSize_; }
-                    set { normalizedReticleSize_ = value; }
-                }
-
-                public string SpawnPointGuid
-                {
-                    get { return spawnPointGuid_; }
-                    set { spawnPointGuid_ = pb::ProtoPreconditions.CheckNotNull(value, "value"); }
-                }
-
-                public int HitPokemon
-                {
-                    get { return hitPokemon_; }
-                    set { hitPokemon_ = value; }
-                }
-
-                public ulong SpinModifier
-                {
-                    get { return spinModifier_; }
-                    set { spinModifier_ = value; }
-                }
-
-                public ulong NormalizedHitPosition
-                {
-                    get { return normalizedHitPosition_; }
-                    set { normalizedHitPosition_ = value; }
-                }
-
-                pbr::MessageDescriptor pb::IMessage.Descriptor
-                {
-                    get { return Descriptor; }
-                }
-
-                public CatchPokemonRequest Clone()
-                {
-                    return new CatchPokemonRequest(this);
-                }
-
-                public bool Equals(CatchPokemonRequest other)
-                {
-                    if (ReferenceEquals(other, null))
-                    {
-                        return false;
-                    }
-                    if (ReferenceEquals(other, this))
-                    {
-                        return true;
-                    }
-                    if (EncounterId != other.EncounterId) return false;
-                    if (Pokeball != other.Pokeball) return false;
-                    if (NormalizedReticleSize != other.NormalizedReticleSize) return false;
-                    if (SpawnPointGuid != other.SpawnPointGuid) return false;
-                    if (HitPokemon != other.HitPokemon) return false;
-                    if (SpinModifier != other.SpinModifier) return false;
-                    if (NormalizedHitPosition != other.NormalizedHitPosition) return false;
-                    return true;
-                }
-
-                public void WriteTo(pb::CodedOutputStream output)
-                {
-                    if (EncounterId != 0UL)
-                    {
-                        output.WriteRawTag(9);
-                        output.WriteFixed64(EncounterId);
-                    }
-                    if (Pokeball != 0)
-                    {
-                        output.WriteRawTag(16);
-                        output.WriteInt32(Pokeball);
-                    }
-                    if (NormalizedReticleSize != 0UL)
-                    {
-                        output.WriteRawTag(25);
-                        output.WriteFixed64(NormalizedReticleSize);
-                    }
-                    if (SpawnPointGuid.Length != 0)
-                    {
-                        output.WriteRawTag(34);
-                        output.WriteString(SpawnPointGuid);
-                    }
-                    if (HitPokemon != 0)
-                    {
-                        output.WriteRawTag(40);
-                        output.WriteInt32(HitPokemon);
-                    }
-                    if (SpinModifier != 0UL)
-                    {
-                        output.WriteRawTag(49);
-                        output.WriteFixed64(SpinModifier);
-                    }
-                    if (NormalizedHitPosition != 0UL)
-                    {
-                        output.WriteRawTag(57);
-                        output.WriteFixed64(NormalizedHitPosition);
-                    }
-                }
-
-                public int CalculateSize()
-                {
-                    var size = 0;
-                    if (EncounterId != 0UL)
-                    {
-                        size += 1 + 8;
-                    }
-                    if (Pokeball != 0)
-                    {
-                        size += 1 + pb::CodedOutputStream.ComputeInt32Size(Pokeball);
-                    }
-                    if (NormalizedReticleSize != 0UL)
-                    {
-                        size += 1 + 8;
-                    }
-                    if (SpawnPointGuid.Length != 0)
-                    {
-                        size += 1 + pb::CodedOutputStream.ComputeStringSize(SpawnPointGuid);
-                    }
-                    if (HitPokemon != 0)
-                    {
-                        size += 1 + pb::CodedOutputStream.ComputeInt32Size(HitPokemon);
-                    }
-                    if (SpinModifier != 0UL)
-                    {
-                        size += 1 + 8;
-                    }
-                    if (NormalizedHitPosition != 0UL)
-                    {
-                        size += 1 + 8;
-                    }
-                    return size;
-                }
-
-                public void MergeFrom(CatchPokemonRequest other)
-                {
-                    if (other == null)
-                    {
-                        return;
-                    }
-                    if (other.EncounterId != 0UL)
-                    {
-                        EncounterId = other.EncounterId;
-                    }
-                    if (other.Pokeball != 0)
-                    {
-                        Pokeball = other.Pokeball;
-                    }
-                    if (other.NormalizedReticleSize != 0UL)
-                    {
-                        NormalizedReticleSize = other.NormalizedReticleSize;
-                    }
-                    if (other.SpawnPointGuid.Length != 0)
-                    {
-                        SpawnPointGuid = other.SpawnPointGuid;
-                    }
-                    if (other.HitPokemon != 0)
-                    {
-                        HitPokemon = other.HitPokemon;
-                    }
-                    if (other.SpinModifier != 0UL)
-                    {
-                        SpinModifier = other.SpinModifier;
-                    }
-                    if (other.NormalizedHitPosition != 0UL)
-                    {
-                        NormalizedHitPosition = other.NormalizedHitPosition;
-                    }
-                }
-
-                public void MergeFrom(pb::CodedInputStream input)
-                {
-                    uint tag;
-                    while ((tag = input.ReadTag()) != 0)
-                    {
-                        switch (tag)
-                        {
-                            default:
-                                input.SkipLastField();
-                                break;
-                            case 9:
-                            {
-                                EncounterId = input.ReadFixed64();
-                                break;
-                            }
-                            case 16:
-                            {
-                                Pokeball = input.ReadInt32();
-                                break;
-                            }
-                            case 25:
-                            {
-                                NormalizedReticleSize = input.ReadFixed64();
-                                break;
-                            }
-                            case 34:
-                            {
-                                SpawnPointGuid = input.ReadString();
-                                break;
-                            }
-                            case 40:
-                            {
-                                HitPokemon = input.ReadInt32();
-                                break;
-                            }
-                            case 49:
-                            {
-                                SpinModifier = input.ReadFixed64();
-                                break;
-                            }
-                            case 57:
-                            {
-                                NormalizedHitPosition = input.ReadFixed64();
-                                break;
-                            }
-                        }
-                    }
-                }
-
-                public override bool Equals(object other)
-                {
-                    return Equals(other as CatchPokemonRequest);
-                }
-
-                public override int GetHashCode()
-                {
-                    var hash = 1;
-                    if (EncounterId != 0UL) hash ^= EncounterId.GetHashCode();
-                    if (Pokeball != 0) hash ^= Pokeball.GetHashCode();
-                    if (NormalizedReticleSize != 0UL) hash ^= NormalizedReticleSize.GetHashCode();
-                    if (SpawnPointGuid.Length != 0) hash ^= SpawnPointGuid.GetHashCode();
-                    if (HitPokemon != 0) hash ^= HitPokemon.GetHashCode();
-                    if (SpinModifier != 0UL) hash ^= SpinModifier.GetHashCode();
-                    if (NormalizedHitPosition != 0UL) hash ^= NormalizedHitPosition.GetHashCode();
-                    return hash;
-                }
-
-                partial void OnConstruction();
-
-                public override string ToString()
-                {
-                    return pb::JsonFormatter.ToDiagnosticString(this);
-                }
-            }
-
-            [global::System.Diagnostics.DebuggerNonUserCodeAttribute()]
-            public sealed partial class SettingsGuid : pb::IMessage<SettingsGuid>
-            {
-                /// <summary>Field number for the "guid" field.</summary>
-                public const int GuidFieldNumber = 1;
-
-                private static readonly pb::MessageParser<SettingsGuid> _parser =
-                    new pb::MessageParser<SettingsGuid>(() => new SettingsGuid());
-
-                private pb::ByteString guid_ = pb::ByteString.Empty;
-
-                public SettingsGuid()
-                {
-                    OnConstruction();
-                }
-
-                public SettingsGuid(SettingsGuid other) : this()
-                {
-                    guid_ = other.guid_;
-                }
-
-                public static pb::MessageParser<SettingsGuid> Parser
-                {
-                    get { return _parser; }
-                }
-
-                public static pbr::MessageDescriptor Descriptor
-                {
-                    get { return global::PokemonGo.RocketAPI.GeneratedCode.Request.Descriptor.NestedTypes[11]; }
-                }
-
-                public pb::ByteString Guid
-                {
-                    get { return guid_; }
-                    set { guid_ = pb::ProtoPreconditions.CheckNotNull(value, "value"); }
-                }
-
-                pbr::MessageDescriptor pb::IMessage.Descriptor
-                {
-                    get { return Descriptor; }
-                }
-
-                public SettingsGuid Clone()
-                {
-                    return new SettingsGuid(this);
-                }
-
-                public bool Equals(SettingsGuid other)
-                {
-                    if (ReferenceEquals(other, null))
-                    {
-                        return false;
-                    }
-                    if (ReferenceEquals(other, this))
-                    {
-                        return true;
-                    }
-                    if (Guid != other.Guid) return false;
-                    return true;
-                }
-
-                public void WriteTo(pb::CodedOutputStream output)
-                {
-                    if (Guid.Length != 0)
-                    {
-                        output.WriteRawTag(10);
-                        output.WriteBytes(Guid);
-                    }
-                }
-
-                public int CalculateSize()
-                {
-                    var size = 0;
-                    if (Guid.Length != 0)
-                    {
-                        size += 1 + pb::CodedOutputStream.ComputeBytesSize(Guid);
-                    }
-                    return size;
-                }
-
-                public void MergeFrom(SettingsGuid other)
-                {
-                    if (other == null)
-                    {
-                        return;
-                    }
-                    if (other.Guid.Length != 0)
-                    {
-                        Guid = other.Guid;
-                    }
-                }
-
-                public void MergeFrom(pb::CodedInputStream input)
-                {
-                    uint tag;
-                    while ((tag = input.ReadTag()) != 0)
-                    {
-                        switch (tag)
-                        {
-                            default:
-                                input.SkipLastField();
-                                break;
-                            case 10:
-                            {
-                                Guid = input.ReadBytes();
-                                break;
-                            }
-                        }
-                    }
-                }
-
-                public override bool Equals(object other)
-                {
-                    return Equals(other as SettingsGuid);
-                }
-
-                public override int GetHashCode()
-                {
-                    var hash = 1;
-                    if (Guid.Length != 0) hash ^= Guid.GetHashCode();
-                    return hash;
-                }
-
-                partial void OnConstruction();
-
-                public override string ToString()
-                {
-                    return pb::JsonFormatter.ToDiagnosticString(this);
-                }
-            }
-
-            [global::System.Diagnostics.DebuggerNonUserCodeAttribute()]
-            public sealed partial class Time : pb::IMessage<Time>
-            {
-                /// <summary>Field number for the "time" field.</summary>
-                public const int Time_FieldNumber = 1;
-
-                private static readonly pb::MessageParser<Time> _parser = new pb::MessageParser<Time>(() => new Time());
-                private long time_;
-
-                public Time()
-                {
-                    OnConstruction();
-                }
-
-                public Time(Time other) : this()
-                {
-                    time_ = other.time_;
-                }
-
-                public static pb::MessageParser<Time> Parser
-                {
-                    get { return _parser; }
-                }
-
-                public static pbr::MessageDescriptor Descriptor
-                {
-                    get { return global::PokemonGo.RocketAPI.GeneratedCode.Request.Descriptor.NestedTypes[12]; }
-                }
-
-                public long Time_
-                {
-                    get { return time_; }
-                    set { time_ = value; }
-                }
-
-                pbr::MessageDescriptor pb::IMessage.Descriptor
-                {
-                    get { return Descriptor; }
-                }
-
-                public Time Clone()
-                {
-                    return new Time(this);
-                }
-
-                public bool Equals(Time other)
-                {
-                    if (ReferenceEquals(other, null))
-                    {
-                        return false;
-                    }
-                    if (ReferenceEquals(other, this))
-                    {
-                        return true;
-                    }
-                    if (Time_ != other.Time_) return false;
-                    return true;
-                }
-
-                public void WriteTo(pb::CodedOutputStream output)
-                {
-                    if (Time_ != 0L)
-                    {
-                        output.WriteRawTag(8);
-                        output.WriteInt64(Time_);
-                    }
-                }
-
-                public int CalculateSize()
-                {
-                    var size = 0;
-                    if (Time_ != 0L)
-                    {
-                        size += 1 + pb::CodedOutputStream.ComputeInt64Size(Time_);
-                    }
-                    return size;
-                }
-
-                public void MergeFrom(Time other)
-                {
-                    if (other == null)
-                    {
-                        return;
-                    }
-                    if (other.Time_ != 0L)
-                    {
-                        Time_ = other.Time_;
-                    }
-                }
-
-                public void MergeFrom(pb::CodedInputStream input)
-                {
-                    uint tag;
-                    while ((tag = input.ReadTag()) != 0)
-                    {
-                        switch (tag)
-                        {
-                            default:
-                                input.SkipLastField();
-                                break;
-                            case 8:
-                            {
-                                Time_ = input.ReadInt64();
-                                break;
-                            }
-                        }
-                    }
-                }
-
-                public override bool Equals(object other)
-                {
-                    return Equals(other as Time);
-                }
-
-                public override int GetHashCode()
-                {
-                    var hash = 1;
-                    if (Time_ != 0L) hash ^= Time_.GetHashCode();
-                    return hash;
-                }
-
-                partial void OnConstruction();
-
-                public override string ToString()
-                {
-                    return pb::JsonFormatter.ToDiagnosticString(this);
-                }
-            }
-        }
-
-        #endregion
-    }
-
-    #endregion
-}
-
-#endregion Designer generated code
\ No newline at end of file
diff --git a/PokemonGo.RocketAPI/GeneratedCode/Response.cs b/PokemonGo.RocketAPI/GeneratedCode/Response.cs
deleted file mode 100644
index 1e44d81..0000000
--- a/PokemonGo.RocketAPI/GeneratedCode/Response.cs
+++ /dev/null
@@ -1,1131 +0,0 @@
-#pragma warning disable 1591, 0612, 3021
-
-#region Designer generated code
-
-#region
-
-using pb = global::Google.Protobuf;
-using pbc = global::Google.Protobuf.Collections;
-using pbr = global::Google.Protobuf.Reflection;
-using scg = global::System.Collections.Generic;
-
-#endregion
-
-namespace PokemonGo.RocketAPI.GeneratedCode
-{
-    /// <summary>Holder for reflection information generated from Response.proto</summary>
-    [global::System.Diagnostics.DebuggerNonUserCodeAttribute()]
-    public static partial class ResponseReflection
-    {
-        #region Descriptor
-
-        /// <summary>File descriptor for Response.proto</summary>
-        public static pbr::FileDescriptor Descriptor
-        {
-            get { return descriptor; }
-        }
-
-        private static pbr::FileDescriptor descriptor;
-
-        static ResponseReflection()
-        {
-            var descriptorData = global::System.Convert.FromBase64String(
-                string.Concat(
-                    "Cg5SZXNwb25zZS5wcm90bxIhUG9rZW1vbkdvLlJvY2tldEFQSS5HZW5lcmF0",
-                    "ZWRDb2RlIrYFCghSZXNwb25zZRIQCgh1bmtub3duMRgBIAEoBRIQCgh1bmtu",
-                    "b3duMhgCIAEoAxIPCgdhcGlfdXJsGAMgASgJEkYKCHVua25vd242GAYgASgL",
-                    "MjQuUG9rZW1vbkdvLlJvY2tldEFQSS5HZW5lcmF0ZWRDb2RlLlJlc3BvbnNl",
-                    "LlVua25vd242Ej4KBGF1dGgYByABKAsyMC5Qb2tlbW9uR28uUm9ja2V0QVBJ",
-                    "LkdlbmVyYXRlZENvZGUuUmVzcG9uc2UuQXV0aBIPCgdwYXlsb2FkGGQgAygM",
-                    "EhQKDGVycm9yTWVzc2FnZRhlIAEoCRqLAQoIVW5rbm93bjYSEAoIdW5rbm93",
-                    "bjEYASABKAUSTwoIdW5rbm93bjIYAiABKAsyPS5Qb2tlbW9uR28uUm9ja2V0",
-                    "QVBJLkdlbmVyYXRlZENvZGUuUmVzcG9uc2UuVW5rbm93bjYuVW5rbm93bjIa",
-                    "HAoIVW5rbm93bjISEAoIdW5rbm93bjEYASABKAwaPwoEQXV0aBIRCgl1bmtu",
-                    "b3duNzEYASABKAwSEQoJdGltZXN0YW1wGAIgASgDEhEKCXVua25vd243MxgD",
-                    "IAEoDBr2AQocUmVjeWNsZUludmVudG9yeUl0ZW1SZXNwb25zZRJfCgZyZXN1",
-                    "bHQYASABKA4yTy5Qb2tlbW9uR28uUm9ja2V0QVBJLkdlbmVyYXRlZENvZGUu",
-                    "UmVzcG9uc2UuUmVjeWNsZUludmVudG9yeUl0ZW1SZXNwb25zZS5SZXN1bHQS",
-                    "EQoJbmV3X2NvdW50GAIgASgFImIKBlJlc3VsdBIJCgVVTlNFVBAAEgsKB1NV",
-                    "Q0NFU1MQARIbChdFUlJPUl9OT1RfRU5PVUdIX0NPUElFUxACEiMKH0VSUk9S",
-                    "X0NBTk5PVF9SRUNZQ0xFX0lOQ1VCQVRPUlMQA2IGcHJvdG8z"));
-            descriptor = pbr::FileDescriptor.FromGeneratedCode(descriptorData,
-                new pbr::FileDescriptor[] {},
-                new pbr::GeneratedClrTypeInfo(null, new pbr::GeneratedClrTypeInfo[]
-                {
-                    new pbr::GeneratedClrTypeInfo(typeof(global::PokemonGo.RocketAPI.GeneratedCode.Response),
-                        global::PokemonGo.RocketAPI.GeneratedCode.Response.Parser,
-                        new[] {"Unknown1", "Unknown2", "ApiUrl", "Unknown6", "Auth", "Payload", "ErrorMessage"}, null,
-                        null, new pbr::GeneratedClrTypeInfo[]
-                        {
-                            new pbr::GeneratedClrTypeInfo(
-                                typeof(global::PokemonGo.RocketAPI.GeneratedCode.Response.Types.Unknown6),
-                                global::PokemonGo.RocketAPI.GeneratedCode.Response.Types.Unknown6.Parser,
-                                new[] {"Unknown1", "Unknown2"}, null, null,
-                                new pbr::GeneratedClrTypeInfo[]
-                                {
-                                    new pbr::GeneratedClrTypeInfo(
-                                        typeof(
-                                            global::PokemonGo.RocketAPI.GeneratedCode.Response.Types.Unknown6.Types.
-                                                Unknown2),
-                                        global::PokemonGo.RocketAPI.GeneratedCode.Response.Types.Unknown6.Types.Unknown2
-                                            .Parser, new[] {"Unknown1"}, null, null, null)
-                                }),
-                            new pbr::GeneratedClrTypeInfo(
-                                typeof(global::PokemonGo.RocketAPI.GeneratedCode.Response.Types.Auth),
-                                global::PokemonGo.RocketAPI.GeneratedCode.Response.Types.Auth.Parser,
-                                new[] {"Unknown71", "Timestamp", "Unknown73"}, null, null, null),
-                            new pbr::GeneratedClrTypeInfo(
-                                typeof(
-                                    global::PokemonGo.RocketAPI.GeneratedCode.Response.Types.
-                                        RecycleInventoryItemResponse),
-                                global::PokemonGo.RocketAPI.GeneratedCode.Response.Types.RecycleInventoryItemResponse
-                                    .Parser, new[] {"Result", "NewCount"}, null,
-                                new[]
-                                {
-                                    typeof(
-                                        global::PokemonGo.RocketAPI.GeneratedCode.Response.Types.
-                                            RecycleInventoryItemResponse.Types.Result)
-                                }, null)
-                        })
-                }));
-        }
-
-        #endregion
-    }
-
-    #region Messages
-
-    [global::System.Diagnostics.DebuggerNonUserCodeAttribute()]
-    public sealed partial class Response : pb::IMessage<Response>
-    {
-        /// <summary>Field number for the "unknown1" field.</summary>
-        public const int Unknown1FieldNumber = 1;
-
-        /// <summary>Field number for the "unknown2" field.</summary>
-        public const int Unknown2FieldNumber = 2;
-
-        /// <summary>Field number for the "api_url" field.</summary>
-        public const int ApiUrlFieldNumber = 3;
-
-        /// <summary>Field number for the "unknown6" field.</summary>
-        public const int Unknown6FieldNumber = 6;
-
-        /// <summary>Field number for the "auth" field.</summary>
-        public const int AuthFieldNumber = 7;
-
-        /// <summary>Field number for the "payload" field.</summary>
-        public const int PayloadFieldNumber = 100;
-
-        /// <summary>Field number for the "errorMessage" field.</summary>
-        public const int ErrorMessageFieldNumber = 101;
-
-        private static readonly pb::MessageParser<Response> _parser =
-            new pb::MessageParser<Response>(() => new Response());
-
-        private static readonly pb::FieldCodec<pb::ByteString> _repeated_payload_codec
-            = pb::FieldCodec.ForBytes(802);
-
-        private readonly pbc::RepeatedField<pb::ByteString> payload_ = new pbc::RepeatedField<pb::ByteString>();
-        private string apiUrl_ = "";
-        private global::PokemonGo.RocketAPI.GeneratedCode.Response.Types.Auth auth_;
-        private string errorMessage_ = "";
-        private int unknown1_;
-        private long unknown2_;
-        private global::PokemonGo.RocketAPI.GeneratedCode.Response.Types.Unknown6 unknown6_;
-
-        public Response()
-        {
-            OnConstruction();
-        }
-
-        public Response(Response other) : this()
-        {
-            unknown1_ = other.unknown1_;
-            unknown2_ = other.unknown2_;
-            apiUrl_ = other.apiUrl_;
-            Unknown6 = other.unknown6_ != null ? other.Unknown6.Clone() : null;
-            Auth = other.auth_ != null ? other.Auth.Clone() : null;
-            payload_ = other.payload_.Clone();
-            errorMessage_ = other.errorMessage_;
-        }
-
-        public static pb::MessageParser<Response> Parser
-        {
-            get { return _parser; }
-        }
-
-        public static pbr::MessageDescriptor Descriptor
-        {
-            get { return global::PokemonGo.RocketAPI.GeneratedCode.ResponseReflection.Descriptor.MessageTypes[0]; }
-        }
-
-        public int Unknown1
-        {
-            get { return unknown1_; }
-            set { unknown1_ = value; }
-        }
-
-        public long Unknown2
-        {
-            get { return unknown2_; }
-            set { unknown2_ = value; }
-        }
-
-        public string ApiUrl
-        {
-            get { return apiUrl_; }
-            set { apiUrl_ = pb::ProtoPreconditions.CheckNotNull(value, "value"); }
-        }
-
-        public global::PokemonGo.RocketAPI.GeneratedCode.Response.Types.Unknown6 Unknown6
-        {
-            get { return unknown6_; }
-            set { unknown6_ = value; }
-        }
-
-        public global::PokemonGo.RocketAPI.GeneratedCode.Response.Types.Auth Auth
-        {
-            get { return auth_; }
-            set { auth_ = value; }
-        }
-
-        public pbc::RepeatedField<pb::ByteString> Payload
-        {
-            get { return payload_; }
-        }
-
-        public string ErrorMessage
-        {
-            get { return errorMessage_; }
-            set { errorMessage_ = pb::ProtoPreconditions.CheckNotNull(value, "value"); }
-        }
-
-        pbr::MessageDescriptor pb::IMessage.Descriptor
-        {
-            get { return Descriptor; }
-        }
-
-        public Response Clone()
-        {
-            return new Response(this);
-        }
-
-        public bool Equals(Response other)
-        {
-            if (ReferenceEquals(other, null))
-            {
-                return false;
-            }
-            if (ReferenceEquals(other, this))
-            {
-                return true;
-            }
-            if (Unknown1 != other.Unknown1) return false;
-            if (Unknown2 != other.Unknown2) return false;
-            if (ApiUrl != other.ApiUrl) return false;
-            if (!Equals(Unknown6, other.Unknown6)) return false;
-            if (!Equals(Auth, other.Auth)) return false;
-            if (!payload_.Equals(other.payload_)) return false;
-            if (ErrorMessage != other.ErrorMessage) return false;
-            return true;
-        }
-
-        public void WriteTo(pb::CodedOutputStream output)
-        {
-            if (Unknown1 != 0)
-            {
-                output.WriteRawTag(8);
-                output.WriteInt32(Unknown1);
-            }
-            if (Unknown2 != 0L)
-            {
-                output.WriteRawTag(16);
-                output.WriteInt64(Unknown2);
-            }
-            if (ApiUrl.Length != 0)
-            {
-                output.WriteRawTag(26);
-                output.WriteString(ApiUrl);
-            }
-            if (unknown6_ != null)
-            {
-                output.WriteRawTag(50);
-                output.WriteMessage(Unknown6);
-            }
-            if (auth_ != null)
-            {
-                output.WriteRawTag(58);
-                output.WriteMessage(Auth);
-            }
-            payload_.WriteTo(output, _repeated_payload_codec);
-            if (ErrorMessage.Length != 0)
-            {
-                output.WriteRawTag(170, 6);
-                output.WriteString(ErrorMessage);
-            }
-        }
-
-        public int CalculateSize()
-        {
-            var size = 0;
-            if (Unknown1 != 0)
-            {
-                size += 1 + pb::CodedOutputStream.ComputeInt32Size(Unknown1);
-            }
-            if (Unknown2 != 0L)
-            {
-                size += 1 + pb::CodedOutputStream.ComputeInt64Size(Unknown2);
-            }
-            if (ApiUrl.Length != 0)
-            {
-                size += 1 + pb::CodedOutputStream.ComputeStringSize(ApiUrl);
-            }
-            if (unknown6_ != null)
-            {
-                size += 1 + pb::CodedOutputStream.ComputeMessageSize(Unknown6);
-            }
-            if (auth_ != null)
-            {
-                size += 1 + pb::CodedOutputStream.ComputeMessageSize(Auth);
-            }
-            size += payload_.CalculateSize(_repeated_payload_codec);
-            if (ErrorMessage.Length != 0)
-            {
-                size += 2 + pb::CodedOutputStream.ComputeStringSize(ErrorMessage);
-            }
-            return size;
-        }
-
-        public void MergeFrom(Response other)
-        {
-            if (other == null)
-            {
-                return;
-            }
-            if (other.Unknown1 != 0)
-            {
-                Unknown1 = other.Unknown1;
-            }
-            if (other.Unknown2 != 0L)
-            {
-                Unknown2 = other.Unknown2;
-            }
-            if (other.ApiUrl.Length != 0)
-            {
-                ApiUrl = other.ApiUrl;
-            }
-            if (other.unknown6_ != null)
-            {
-                if (unknown6_ == null)
-                {
-                    unknown6_ = new global::PokemonGo.RocketAPI.GeneratedCode.Response.Types.Unknown6();
-                }
-                Unknown6.MergeFrom(other.Unknown6);
-            }
-            if (other.auth_ != null)
-            {
-                if (auth_ == null)
-                {
-                    auth_ = new global::PokemonGo.RocketAPI.GeneratedCode.Response.Types.Auth();
-                }
-                Auth.MergeFrom(other.Auth);
-            }
-            payload_.Add(other.payload_);
-            if (other.ErrorMessage.Length != 0)
-            {
-                ErrorMessage = other.ErrorMessage;
-            }
-        }
-
-        public void MergeFrom(pb::CodedInputStream input)
-        {
-            uint tag;
-            while ((tag = input.ReadTag()) != 0)
-            {
-                switch (tag)
-                {
-                    default:
-                        input.SkipLastField();
-                        break;
-                    case 8:
-                    {
-                        Unknown1 = input.ReadInt32();
-                        break;
-                    }
-                    case 16:
-                    {
-                        Unknown2 = input.ReadInt64();
-                        break;
-                    }
-                    case 26:
-                    {
-                        ApiUrl = input.ReadString();
-                        break;
-                    }
-                    case 50:
-                    {
-                        if (unknown6_ == null)
-                        {
-                            unknown6_ = new global::PokemonGo.RocketAPI.GeneratedCode.Response.Types.Unknown6();
-                        }
-                        input.ReadMessage(unknown6_);
-                        break;
-                    }
-                    case 58:
-                    {
-                        if (auth_ == null)
-                        {
-                            auth_ = new global::PokemonGo.RocketAPI.GeneratedCode.Response.Types.Auth();
-                        }
-                        input.ReadMessage(auth_);
-                        break;
-                    }
-                    case 802:
-                    {
-                        payload_.AddEntriesFrom(input, _repeated_payload_codec);
-                        break;
-                    }
-                    case 810:
-                    {
-                        ErrorMessage = input.ReadString();
-                        break;
-                    }
-                }
-            }
-        }
-
-        public override bool Equals(object other)
-        {
-            return Equals(other as Response);
-        }
-
-        public override int GetHashCode()
-        {
-            var hash = 1;
-            if (Unknown1 != 0) hash ^= Unknown1.GetHashCode();
-            if (Unknown2 != 0L) hash ^= Unknown2.GetHashCode();
-            if (ApiUrl.Length != 0) hash ^= ApiUrl.GetHashCode();
-            if (unknown6_ != null) hash ^= Unknown6.GetHashCode();
-            if (auth_ != null) hash ^= Auth.GetHashCode();
-            hash ^= payload_.GetHashCode();
-            if (ErrorMessage.Length != 0) hash ^= ErrorMessage.GetHashCode();
-            return hash;
-        }
-
-        partial void OnConstruction();
-
-        public override string ToString()
-        {
-            return pb::JsonFormatter.ToDiagnosticString(this);
-        }
-
-        #region Nested types
-
-        /// <summary>Container for nested types declared in the Response message type.</summary>
-        [global::System.Diagnostics.DebuggerNonUserCodeAttribute()]
-        public static partial class Types
-        {
-            [global::System.Diagnostics.DebuggerNonUserCodeAttribute()]
-            public sealed partial class Unknown6 : pb::IMessage<Unknown6>
-            {
-                /// <summary>Field number for the "unknown1" field.</summary>
-                public const int Unknown1FieldNumber = 1;
-
-                /// <summary>Field number for the "unknown2" field.</summary>
-                public const int Unknown2FieldNumber = 2;
-
-                private static readonly pb::MessageParser<Unknown6> _parser =
-                    new pb::MessageParser<Unknown6>(() => new Unknown6());
-
-                private int unknown1_;
-                private global::PokemonGo.RocketAPI.GeneratedCode.Response.Types.Unknown6.Types.Unknown2 unknown2_;
-
-                public Unknown6()
-                {
-                    OnConstruction();
-                }
-
-                public Unknown6(Unknown6 other) : this()
-                {
-                    unknown1_ = other.unknown1_;
-                    Unknown2 = other.unknown2_ != null ? other.Unknown2.Clone() : null;
-                }
-
-                public static pb::MessageParser<Unknown6> Parser
-                {
-                    get { return _parser; }
-                }
-
-                public static pbr::MessageDescriptor Descriptor
-                {
-                    get { return global::PokemonGo.RocketAPI.GeneratedCode.Response.Descriptor.NestedTypes[0]; }
-                }
-
-                public int Unknown1
-                {
-                    get { return unknown1_; }
-                    set { unknown1_ = value; }
-                }
-
-                public global::PokemonGo.RocketAPI.GeneratedCode.Response.Types.Unknown6.Types.Unknown2 Unknown2
-                {
-                    get { return unknown2_; }
-                    set { unknown2_ = value; }
-                }
-
-                pbr::MessageDescriptor pb::IMessage.Descriptor
-                {
-                    get { return Descriptor; }
-                }
-
-                public Unknown6 Clone()
-                {
-                    return new Unknown6(this);
-                }
-
-                public bool Equals(Unknown6 other)
-                {
-                    if (ReferenceEquals(other, null))
-                    {
-                        return false;
-                    }
-                    if (ReferenceEquals(other, this))
-                    {
-                        return true;
-                    }
-                    if (Unknown1 != other.Unknown1) return false;
-                    if (!Equals(Unknown2, other.Unknown2)) return false;
-                    return true;
-                }
-
-                public void WriteTo(pb::CodedOutputStream output)
-                {
-                    if (Unknown1 != 0)
-                    {
-                        output.WriteRawTag(8);
-                        output.WriteInt32(Unknown1);
-                    }
-                    if (unknown2_ != null)
-                    {
-                        output.WriteRawTag(18);
-                        output.WriteMessage(Unknown2);
-                    }
-                }
-
-                public int CalculateSize()
-                {
-                    var size = 0;
-                    if (Unknown1 != 0)
-                    {
-                        size += 1 + pb::CodedOutputStream.ComputeInt32Size(Unknown1);
-                    }
-                    if (unknown2_ != null)
-                    {
-                        size += 1 + pb::CodedOutputStream.ComputeMessageSize(Unknown2);
-                    }
-                    return size;
-                }
-
-                public void MergeFrom(Unknown6 other)
-                {
-                    if (other == null)
-                    {
-                        return;
-                    }
-                    if (other.Unknown1 != 0)
-                    {
-                        Unknown1 = other.Unknown1;
-                    }
-                    if (other.unknown2_ != null)
-                    {
-                        if (unknown2_ == null)
-                        {
-                            unknown2_ =
-                                new global::PokemonGo.RocketAPI.GeneratedCode.Response.Types.Unknown6.Types.Unknown2();
-                        }
-                        Unknown2.MergeFrom(other.Unknown2);
-                    }
-                }
-
-                public void MergeFrom(pb::CodedInputStream input)
-                {
-                    uint tag;
-                    while ((tag = input.ReadTag()) != 0)
-                    {
-                        switch (tag)
-                        {
-                            default:
-                                input.SkipLastField();
-                                break;
-                            case 8:
-                            {
-                                Unknown1 = input.ReadInt32();
-                                break;
-                            }
-                            case 18:
-                            {
-                                if (unknown2_ == null)
-                                {
-                                    unknown2_ =
-                                        new global::PokemonGo.RocketAPI.GeneratedCode.Response.Types.Unknown6.Types.
-                                            Unknown2();
-                                }
-                                input.ReadMessage(unknown2_);
-                                break;
-                            }
-                        }
-                    }
-                }
-
-                public override bool Equals(object other)
-                {
-                    return Equals(other as Unknown6);
-                }
-
-                public override int GetHashCode()
-                {
-                    var hash = 1;
-                    if (Unknown1 != 0) hash ^= Unknown1.GetHashCode();
-                    if (unknown2_ != null) hash ^= Unknown2.GetHashCode();
-                    return hash;
-                }
-
-                partial void OnConstruction();
-
-                public override string ToString()
-                {
-                    return pb::JsonFormatter.ToDiagnosticString(this);
-                }
-
-                #region Nested types
-
-                /// <summary>Container for nested types declared in the Unknown6 message type.</summary>
-                [global::System.Diagnostics.DebuggerNonUserCodeAttribute()]
-                public static partial class Types
-                {
-                    [global::System.Diagnostics.DebuggerNonUserCodeAttribute()]
-                    public sealed partial class Unknown2 : pb::IMessage<Unknown2>
-                    {
-                        /// <summary>Field number for the "unknown1" field.</summary>
-                        public const int Unknown1FieldNumber = 1;
-
-                        private static readonly pb::MessageParser<Unknown2> _parser =
-                            new pb::MessageParser<Unknown2>(() => new Unknown2());
-
-                        private pb::ByteString unknown1_ = pb::ByteString.Empty;
-
-                        public Unknown2()
-                        {
-                            OnConstruction();
-                        }
-
-                        public Unknown2(Unknown2 other) : this()
-                        {
-                            unknown1_ = other.unknown1_;
-                        }
-
-                        public static pb::MessageParser<Unknown2> Parser
-                        {
-                            get { return _parser; }
-                        }
-
-                        public static pbr::MessageDescriptor Descriptor
-                        {
-                            get
-                            {
-                                return
-                                    global::PokemonGo.RocketAPI.GeneratedCode.Response.Types.Unknown6.Descriptor
-                                        .NestedTypes[0];
-                            }
-                        }
-
-                        public pb::ByteString Unknown1
-                        {
-                            get { return unknown1_; }
-                            set { unknown1_ = pb::ProtoPreconditions.CheckNotNull(value, "value"); }
-                        }
-
-                        pbr::MessageDescriptor pb::IMessage.Descriptor
-                        {
-                            get { return Descriptor; }
-                        }
-
-                        public Unknown2 Clone()
-                        {
-                            return new Unknown2(this);
-                        }
-
-                        public bool Equals(Unknown2 other)
-                        {
-                            if (ReferenceEquals(other, null))
-                            {
-                                return false;
-                            }
-                            if (ReferenceEquals(other, this))
-                            {
-                                return true;
-                            }
-                            if (Unknown1 != other.Unknown1) return false;
-                            return true;
-                        }
-
-                        public void WriteTo(pb::CodedOutputStream output)
-                        {
-                            if (Unknown1.Length != 0)
-                            {
-                                output.WriteRawTag(10);
-                                output.WriteBytes(Unknown1);
-                            }
-                        }
-
-                        public int CalculateSize()
-                        {
-                            var size = 0;
-                            if (Unknown1.Length != 0)
-                            {
-                                size += 1 + pb::CodedOutputStream.ComputeBytesSize(Unknown1);
-                            }
-                            return size;
-                        }
-
-                        public void MergeFrom(Unknown2 other)
-                        {
-                            if (other == null)
-                            {
-                                return;
-                            }
-                            if (other.Unknown1.Length != 0)
-                            {
-                                Unknown1 = other.Unknown1;
-                            }
-                        }
-
-                        public void MergeFrom(pb::CodedInputStream input)
-                        {
-                            uint tag;
-                            while ((tag = input.ReadTag()) != 0)
-                            {
-                                switch (tag)
-                                {
-                                    default:
-                                        input.SkipLastField();
-                                        break;
-                                    case 10:
-                                    {
-                                        Unknown1 = input.ReadBytes();
-                                        break;
-                                    }
-                                }
-                            }
-                        }
-
-                        public override bool Equals(object other)
-                        {
-                            return Equals(other as Unknown2);
-                        }
-
-                        public override int GetHashCode()
-                        {
-                            var hash = 1;
-                            if (Unknown1.Length != 0) hash ^= Unknown1.GetHashCode();
-                            return hash;
-                        }
-
-                        partial void OnConstruction();
-
-                        public override string ToString()
-                        {
-                            return pb::JsonFormatter.ToDiagnosticString(this);
-                        }
-                    }
-                }
-
-                #endregion
-            }
-
-            [global::System.Diagnostics.DebuggerNonUserCodeAttribute()]
-            public sealed partial class Auth : pb::IMessage<Auth>
-            {
-                /// <summary>Field number for the "unknown71" field.</summary>
-                public const int Unknown71FieldNumber = 1;
-
-                /// <summary>Field number for the "timestamp" field.</summary>
-                public const int TimestampFieldNumber = 2;
-
-                /// <summary>Field number for the "unknown73" field.</summary>
-                public const int Unknown73FieldNumber = 3;
-
-                private static readonly pb::MessageParser<Auth> _parser = new pb::MessageParser<Auth>(() => new Auth());
-                private long timestamp_;
-                private pb::ByteString unknown71_ = pb::ByteString.Empty;
-                private pb::ByteString unknown73_ = pb::ByteString.Empty;
-
-                public Auth()
-                {
-                    OnConstruction();
-                }
-
-                public Auth(Auth other) : this()
-                {
-                    unknown71_ = other.unknown71_;
-                    timestamp_ = other.timestamp_;
-                    unknown73_ = other.unknown73_;
-                }
-
-                public static pb::MessageParser<Auth> Parser
-                {
-                    get { return _parser; }
-                }
-
-                public static pbr::MessageDescriptor Descriptor
-                {
-                    get { return global::PokemonGo.RocketAPI.GeneratedCode.Response.Descriptor.NestedTypes[1]; }
-                }
-
-                public pb::ByteString Unknown71
-                {
-                    get { return unknown71_; }
-                    set { unknown71_ = pb::ProtoPreconditions.CheckNotNull(value, "value"); }
-                }
-
-                public long Timestamp
-                {
-                    get { return timestamp_; }
-                    set { timestamp_ = value; }
-                }
-
-                public pb::ByteString Unknown73
-                {
-                    get { return unknown73_; }
-                    set { unknown73_ = pb::ProtoPreconditions.CheckNotNull(value, "value"); }
-                }
-
-                pbr::MessageDescriptor pb::IMessage.Descriptor
-                {
-                    get { return Descriptor; }
-                }
-
-                public Auth Clone()
-                {
-                    return new Auth(this);
-                }
-
-                public bool Equals(Auth other)
-                {
-                    if (ReferenceEquals(other, null))
-                    {
-                        return false;
-                    }
-                    if (ReferenceEquals(other, this))
-                    {
-                        return true;
-                    }
-                    if (Unknown71 != other.Unknown71) return false;
-                    if (Timestamp != other.Timestamp) return false;
-                    if (Unknown73 != other.Unknown73) return false;
-                    return true;
-                }
-
-                public void WriteTo(pb::CodedOutputStream output)
-                {
-                    if (Unknown71.Length != 0)
-                    {
-                        output.WriteRawTag(10);
-                        output.WriteBytes(Unknown71);
-                    }
-                    if (Timestamp != 0L)
-                    {
-                        output.WriteRawTag(16);
-                        output.WriteInt64(Timestamp);
-                    }
-                    if (Unknown73.Length != 0)
-                    {
-                        output.WriteRawTag(26);
-                        output.WriteBytes(Unknown73);
-                    }
-                }
-
-                public int CalculateSize()
-                {
-                    var size = 0;
-                    if (Unknown71.Length != 0)
-                    {
-                        size += 1 + pb::CodedOutputStream.ComputeBytesSize(Unknown71);
-                    }
-                    if (Timestamp != 0L)
-                    {
-                        size += 1 + pb::CodedOutputStream.ComputeInt64Size(Timestamp);
-                    }
-                    if (Unknown73.Length != 0)
-                    {
-                        size += 1 + pb::CodedOutputStream.ComputeBytesSize(Unknown73);
-                    }
-                    return size;
-                }
-
-                public void MergeFrom(Auth other)
-                {
-                    if (other == null)
-                    {
-                        return;
-                    }
-                    if (other.Unknown71.Length != 0)
-                    {
-                        Unknown71 = other.Unknown71;
-                    }
-                    if (other.Timestamp != 0L)
-                    {
-                        Timestamp = other.Timestamp;
-                    }
-                    if (other.Unknown73.Length != 0)
-                    {
-                        Unknown73 = other.Unknown73;
-                    }
-                }
-
-                public void MergeFrom(pb::CodedInputStream input)
-                {
-                    uint tag;
-                    while ((tag = input.ReadTag()) != 0)
-                    {
-                        switch (tag)
-                        {
-                            default:
-                                input.SkipLastField();
-                                break;
-                            case 10:
-                            {
-                                Unknown71 = input.ReadBytes();
-                                break;
-                            }
-                            case 16:
-                            {
-                                Timestamp = input.ReadInt64();
-                                break;
-                            }
-                            case 26:
-                            {
-                                Unknown73 = input.ReadBytes();
-                                break;
-                            }
-                        }
-                    }
-                }
-
-                public override bool Equals(object other)
-                {
-                    return Equals(other as Auth);
-                }
-
-                public override int GetHashCode()
-                {
-                    var hash = 1;
-                    if (Unknown71.Length != 0) hash ^= Unknown71.GetHashCode();
-                    if (Timestamp != 0L) hash ^= Timestamp.GetHashCode();
-                    if (Unknown73.Length != 0) hash ^= Unknown73.GetHashCode();
-                    return hash;
-                }
-
-                partial void OnConstruction();
-
-                public override string ToString()
-                {
-                    return pb::JsonFormatter.ToDiagnosticString(this);
-                }
-            }
-
-            [global::System.Diagnostics.DebuggerNonUserCodeAttribute()]
-            public sealed partial class RecycleInventoryItemResponse : pb::IMessage<RecycleInventoryItemResponse>
-            {
-                /// <summary>Field number for the "result" field.</summary>
-                public const int ResultFieldNumber = 1;
-
-                /// <summary>Field number for the "new_count" field.</summary>
-                public const int NewCountFieldNumber = 2;
-
-                private static readonly pb::MessageParser<RecycleInventoryItemResponse> _parser =
-                    new pb::MessageParser<RecycleInventoryItemResponse>(() => new RecycleInventoryItemResponse());
-
-                private int newCount_;
-
-                private
-                    global::PokemonGo.RocketAPI.GeneratedCode.Response.Types.RecycleInventoryItemResponse.Types.Result
-                    result_ = 0;
-
-                public RecycleInventoryItemResponse()
-                {
-                    OnConstruction();
-                }
-
-                public RecycleInventoryItemResponse(RecycleInventoryItemResponse other) : this()
-                {
-                    result_ = other.result_;
-                    newCount_ = other.newCount_;
-                }
-
-                public static pb::MessageParser<RecycleInventoryItemResponse> Parser
-                {
-                    get { return _parser; }
-                }
-
-                public static pbr::MessageDescriptor Descriptor
-                {
-                    get { return global::PokemonGo.RocketAPI.GeneratedCode.Response.Descriptor.NestedTypes[2]; }
-                }
-
-                public
-                    global::PokemonGo.RocketAPI.GeneratedCode.Response.Types.RecycleInventoryItemResponse.Types.Result
-                    Result
-                {
-                    get { return result_; }
-                    set { result_ = value; }
-                }
-
-                public int NewCount
-                {
-                    get { return newCount_; }
-                    set { newCount_ = value; }
-                }
-
-                pbr::MessageDescriptor pb::IMessage.Descriptor
-                {
-                    get { return Descriptor; }
-                }
-
-                public RecycleInventoryItemResponse Clone()
-                {
-                    return new RecycleInventoryItemResponse(this);
-                }
-
-                public bool Equals(RecycleInventoryItemResponse other)
-                {
-                    if (ReferenceEquals(other, null))
-                    {
-                        return false;
-                    }
-                    if (ReferenceEquals(other, this))
-                    {
-                        return true;
-                    }
-                    if (Result != other.Result) return false;
-                    if (NewCount != other.NewCount) return false;
-                    return true;
-                }
-
-                public void WriteTo(pb::CodedOutputStream output)
-                {
-                    if (Result != 0)
-                    {
-                        output.WriteRawTag(8);
-                        output.WriteEnum((int) Result);
-                    }
-                    if (NewCount != 0)
-                    {
-                        output.WriteRawTag(16);
-                        output.WriteInt32(NewCount);
-                    }
-                }
-
-                public int CalculateSize()
-                {
-                    var size = 0;
-                    if (Result != 0)
-                    {
-                        size += 1 + pb::CodedOutputStream.ComputeEnumSize((int) Result);
-                    }
-                    if (NewCount != 0)
-                    {
-                        size += 1 + pb::CodedOutputStream.ComputeInt32Size(NewCount);
-                    }
-                    return size;
-                }
-
-                public void MergeFrom(RecycleInventoryItemResponse other)
-                {
-                    if (other == null)
-                    {
-                        return;
-                    }
-                    if (other.Result != 0)
-                    {
-                        Result = other.Result;
-                    }
-                    if (other.NewCount != 0)
-                    {
-                        NewCount = other.NewCount;
-                    }
-                }
-
-                public void MergeFrom(pb::CodedInputStream input)
-                {
-                    uint tag;
-                    while ((tag = input.ReadTag()) != 0)
-                    {
-                        switch (tag)
-                        {
-                            default:
-                                input.SkipLastField();
-                                break;
-                            case 8:
-                            {
-                                result_ =
-                                    (
-                                        global::PokemonGo.RocketAPI.GeneratedCode.Response.Types.
-                                            RecycleInventoryItemResponse.Types.Result) input.ReadEnum();
-                                break;
-                            }
-                            case 16:
-                            {
-                                NewCount = input.ReadInt32();
-                                break;
-                            }
-                        }
-                    }
-                }
-
-                public override bool Equals(object other)
-                {
-                    return Equals(other as RecycleInventoryItemResponse);
-                }
-
-                public override int GetHashCode()
-                {
-                    var hash = 1;
-                    if (Result != 0) hash ^= Result.GetHashCode();
-                    if (NewCount != 0) hash ^= NewCount.GetHashCode();
-                    return hash;
-                }
-
-                partial void OnConstruction();
-
-                public override string ToString()
-                {
-                    return pb::JsonFormatter.ToDiagnosticString(this);
-                }
-
-                #region Nested types
-
-                /// <summary>Container for nested types declared in the RecycleInventoryItemResponse message type.</summary>
-                [global::System.Diagnostics.DebuggerNonUserCodeAttribute()]
-                public static partial class Types
-                {
-                    public enum Result
-                    {
-                        [pbr::OriginalName("UNSET")] Unset = 0,
-                        [pbr::OriginalName("SUCCESS")] Success = 1,
-                        [pbr::OriginalName("ERROR_NOT_ENOUGH_COPIES")] ErrorNotEnoughCopies = 2,
-                        [pbr::OriginalName("ERROR_CANNOT_RECYCLE_INCUBATORS")] ErrorCannotRecycleIncubators = 3,
-                    }
-                }
-
-                #endregion
-            }
-        }
-
-        #endregion
-    }
-
-    #endregion
-}
-
-#endregion Designer generated code
\ No newline at end of file
diff --git a/PokemonGo.RocketAPI/Helpers/Git.cs b/PokemonGo.RocketAPI/Helpers/Git.cs
deleted file mode 100644
index 0630382..0000000
--- a/PokemonGo.RocketAPI/Helpers/Git.cs
+++ /dev/null
@@ -1,56 +0,0 @@
-#region
-
-using PokemonGo.RocketAPI.Logging;
-using System;
-using System.Net;
-using System.Reflection;
-using System.Text.RegularExpressions;
-using System.Threading;
-
-#endregion
-
-
-namespace PokemonGo.RocketAPI.Helpers
-{
-    public static class Git
-    {
-        public static void CheckVersion()
-        {
-            try
-            {
-                var match =
-                    new Regex(
-                        @"\[assembly\: AssemblyVersion\(""(\d{1,})\.(\d{1,})\.(\d{1,})\.(\d{1,})""\)\]")
-                        .Match(DownloadServerVersion());
-
-                if (!match.Success) return;
-                var gitVersion =
-                    new Version(
-                        $"{match.Groups[1]}.{match.Groups[2]}.{match.Groups[3]}.{match.Groups[4]}");
-                if (gitVersion <= Assembly.GetExecutingAssembly().GetName().Version)
-                {
-                    Logger.Write(
-                        "Awesome! You have already got the newest version! " +
-                        Assembly.GetExecutingAssembly().GetName().Version, LogLevel.Info);
-                    return;
-                }
-
-                Logger.Write("There is a new Version available: https://github.com/Spegeli/Pokemon-Go-Rocket-API", LogLevel.Info);
-                Thread.Sleep(1000);
-            }
-            catch (Exception)
-            {
-                // ignored
-            }
-        }
-
-        private static string DownloadServerVersion()
-        {
-            //test
-            using (var wC = new WebClient())
-                return
-                    wC.DownloadString(
-                        "https://raw.githubusercontent.com/Spegeli/Pokemon-Go-Rocket-API/master/PokemonGo.RocketAPI/Properties/AssemblyInfo.cs");
-        }
-    }
-}
\ No newline at end of file
diff --git a/PokemonGo.RocketAPI/Helpers/HttpClientHelper.cs b/PokemonGo.RocketAPI/Helpers/HttpClientHelper.cs
deleted file mode 100644
index ebfc286..0000000
--- a/PokemonGo.RocketAPI/Helpers/HttpClientHelper.cs
+++ /dev/null
@@ -1,30 +0,0 @@
-#region
-
-using System.Collections.Generic;
-using System.Net;
-using System.Net.Http;
-using System.Threading.Tasks;
-
-#endregion
-
-namespace PokemonGo.RocketAPI.Helpers
-{
-    public static class HttpClientHelper
-    {
-        public static async Task<TResponse> PostFormEncodedAsync<TResponse>(string url,
-            params KeyValuePair<string, string>[] keyValuePairs)
-        {
-            var handler = new HttpClientHandler
-            {
-                AutomaticDecompression = DecompressionMethods.GZip,
-                AllowAutoRedirect = false
-            };
-
-            using (var tempHttpClient = new HttpClient(handler))
-            {
-                var response = await tempHttpClient.PostAsync(url, new FormUrlEncodedContent(keyValuePairs));
-                return await response.Content.ReadAsAsync<TResponse>();
-            }
-        }
-    }
-}
\ No newline at end of file
diff --git a/PokemonGo.RocketAPI/Helpers/JsonHelper.cs b/PokemonGo.RocketAPI/Helpers/JsonHelper.cs
deleted file mode 100644
index 2dd2fcd..0000000
--- a/PokemonGo.RocketAPI/Helpers/JsonHelper.cs
+++ /dev/null
@@ -1,17 +0,0 @@
-#region
-
-using Newtonsoft.Json.Linq;
-
-#endregion
-
-namespace PokemonGo.RocketAPI.Helpers
-{
-    public class JsonHelper
-    {
-        public static string GetValue(string json, string key)
-        {
-            var jObject = JObject.Parse(json);
-            return jObject[key].ToString();
-        }
-    }
-}
\ No newline at end of file
diff --git a/PokemonGo.RocketAPI/Helpers/ProtoHelper.cs b/PokemonGo.RocketAPI/Helpers/ProtoHelper.cs
deleted file mode 100644
index 91dcb0d..0000000
--- a/PokemonGo.RocketAPI/Helpers/ProtoHelper.cs
+++ /dev/null
@@ -1,24 +0,0 @@
-#region
-
-using System;
-using System.Collections.Generic;
-using System.Linq;
-
-#endregion
-
-namespace PokemonGo.RocketAPI.Helpers
-{
-    public class ProtoHelper
-    {
-        public static byte[] EncodeUlongList(List<ulong> integers)
-        {
-            var output = new List<byte>();
-            foreach (var integer in integers.OrderBy(c => c))
-            {
-                output.AddRange(VarintBitConverter.GetVarintBytes(integer));
-            }
-
-            return output.ToArray();
-        }
-    }
-}
\ No newline at end of file
diff --git a/PokemonGo.RocketAPI/Helpers/RandomHelper.cs b/PokemonGo.RocketAPI/Helpers/RandomHelper.cs
deleted file mode 100644
index 1639092..0000000
--- a/PokemonGo.RocketAPI/Helpers/RandomHelper.cs
+++ /dev/null
@@ -1,40 +0,0 @@
-#region
-
-using System;
-using System.Threading.Tasks;
-
-#endregion
-
-namespace PokemonGo.RocketAPI.Helpers
-{
-    public class RandomHelper
-    {
-        private static readonly Random _random = new Random();
-        private static readonly Random _rng = new Random();
-
-        public static long GetLongRandom(long min, long max)
-        {
-            var buf = new byte[8];
-            _random.NextBytes(buf);
-            var longRand = BitConverter.ToInt64(buf, 0);
-
-            return Math.Abs(longRand%(max - min)) + min;
-        }
-
-        public static async Task RandomDelay(int maxDelay = 5000)
-        {
-            await Task.Delay(_rng.Next((maxDelay > 500) ? 500 : 0, maxDelay));
-        }
-
-        public static async Task RandomDelay(int min, int max)
-        {
-            await Task.Delay(_rng.Next(min, max));
-        }
-
-        public static int RandomNumber(int min, int max)
-        {
-            Random random = new Random();
-            return random.Next(min, max);
-        }
-    }
-}
\ No newline at end of file
diff --git a/PokemonGo.RocketAPI/Helpers/RequestBuilder.cs b/PokemonGo.RocketAPI/Helpers/RequestBuilder.cs
deleted file mode 100644
index 686d630..0000000
--- a/PokemonGo.RocketAPI/Helpers/RequestBuilder.cs
+++ /dev/null
@@ -1,73 +0,0 @@
-#region
-
-using System.Linq;
-using PokemonGo.RocketAPI.Enums;
-using PokemonGo.RocketAPI.GeneratedCode;
-
-#endregion
-
-namespace PokemonGo.RocketAPI.Helpers
-{
-    public static class RequestBuilder
-    {
-        public static Request GetInitialRequest(string authToken, AuthType authType, double lat, double lng,
-            double altitude, params Request.Types.Requests[] customRequests)
-        {
-            return new Request
-            {
-                Altitude = Utils.FloatAsUlong(altitude),
-                Auth = new Request.Types.AuthInfo
-                {
-                    Provider = authType == AuthType.Google ? "google" : "ptc",
-                    Token = new Request.Types.AuthInfo.Types.JWT
-                    {
-                        Contents = authToken,
-                        Unknown13 = 14
-                    }
-                },
-                Latitude = Utils.FloatAsUlong(lat),
-                Longitude = Utils.FloatAsUlong(lng),
-                RpcId = 1469378659230941192,
-                Unknown1 = 2,
-                Unknown12 = 989, //Required otherwise we receive incompatible protocol
-                Requests =
-                {
-                    customRequests
-                }
-            };
-        }
-
-        public static Request GetInitialRequest(string authToken, AuthType authType, double lat, double lng,
-            double altitude, params RequestType[] customRequestTypes)
-        {
-            var customRequests = customRequestTypes.ToList().Select(c => new Request.Types.Requests {Type = (int) c});
-            return GetInitialRequest(authToken, authType, lat, lng, altitude, customRequests.ToArray());
-        }
-
-        public static Request GetRequest(Request.Types.UnknownAuth unknownAuth, double lat, double lng, double altitude,
-            params Request.Types.Requests[] customRequests)
-        {
-            return new Request
-            {
-                Altitude = Utils.FloatAsUlong(altitude),
-                Unknownauth = unknownAuth,
-                Latitude = Utils.FloatAsUlong(lat),
-                Longitude = Utils.FloatAsUlong(lng),
-                RpcId = 1469378659230941192,
-                Unknown1 = 2,
-                Unknown12 = 989, //Required otherwise we receive incompatible protocol
-                Requests =
-                {
-                    customRequests
-                }
-            };
-        }
-
-        public static Request GetRequest(Request.Types.UnknownAuth unknownAuth, double lat, double lng, double altitude,
-            params RequestType[] customRequestTypes)
-        {
-            var customRequests = customRequestTypes.ToList().Select(c => new Request.Types.Requests {Type = (int) c});
-            return GetRequest(unknownAuth, lat, lng, altitude, customRequests.ToArray());
-        }
-    }
-}
\ No newline at end of file
diff --git a/PokemonGo.RocketAPI/Helpers/RetryHandler.cs b/PokemonGo.RocketAPI/Helpers/RetryHandler.cs
deleted file mode 100644
index 3063811..0000000
--- a/PokemonGo.RocketAPI/Helpers/RetryHandler.cs
+++ /dev/null
@@ -1,48 +0,0 @@
-#region
-
-using PokemonGo.RocketAPI.Logging;
-using System;
-using System.Net;
-using System.Net.Http;
-using System.Threading;
-using System.Threading.Tasks;
-
-#endregion
-
-namespace PokemonGo.RocketAPI.Helpers
-{
-    internal class RetryHandler : DelegatingHandler
-    {
-        private const int MaxRetries = 25;
-
-        public RetryHandler(HttpMessageHandler innerHandler)
-            : base(innerHandler)
-        {
-        }
-
-        protected override async Task<HttpResponseMessage> SendAsync(
-            HttpRequestMessage request,
-            CancellationToken cancellationToken)
-        {
-            for (var i = 0; i <= MaxRetries; i++)
-            {
-                try
-                {
-                    var response = await base.SendAsync(request, cancellationToken);
-                    if (response.StatusCode == HttpStatusCode.BadGateway)
-                        throw new Exception(); //todo: proper implementation
-
-                    return response;
-                }
-                catch (Exception ex)
-                {
-                    Logger.Write($"[#{i} of {MaxRetries}] retry request {request.RequestUri} - Error: {ex}",
-                        LogLevel.Warning);
-                    if (i >= MaxRetries) throw;
-                    await Task.Delay(1000, cancellationToken);
-                }
-            }
-            return null;
-        }
-    }
-}
\ No newline at end of file
diff --git a/PokemonGo.RocketAPI/Helpers/S2Helper.cs b/PokemonGo.RocketAPI/Helpers/S2Helper.cs
deleted file mode 100644
index 973f163..0000000
--- a/PokemonGo.RocketAPI/Helpers/S2Helper.cs
+++ /dev/null
@@ -1,56 +0,0 @@
-#region
-
-using System.Collections.Generic;
-using System.Linq;
-using Google.Common.Geometry;
-
-#endregion
-
-namespace PokemonGo.RocketAPI.Helpers
-{
-    public class S2Helper
-    {
-        public static List<ulong> GetNearbyCellIds(double longitude, double latitude)
-        {
-            var nearbyCellIds = new List<S2CellId>();
-
-            var cellId = S2CellId.FromLatLng(S2LatLng.FromDegrees(latitude, longitude)).ParentForLevel(15);
-            //.Parent.Parent.Parent.Parent.Parent.Parent.Parent.Parent.Parent.Parent.Parent.Parent.Parent.Parent.Parent;
-
-            nearbyCellIds.Add(cellId);
-            for (var i = 0; i < 10; i++)
-            {
-                nearbyCellIds.Add(GetPrevious(cellId, i));
-                nearbyCellIds.Add(GetNext(cellId, i));
-            }
-
-            return nearbyCellIds.Select(c => c.Id).OrderBy(c => c).ToList();
-        }
-
-        private static S2CellId GetNext(S2CellId cellId, int depth)
-        {
-            while (true)
-            {
-                if (depth < 0)
-                    return cellId;
-
-                depth--;
-
-                cellId = cellId.Next;
-            }
-        }
-
-        private static S2CellId GetPrevious(S2CellId cellId, int depth)
-        {
-            while (true)
-            {
-                if (depth < 0)
-                    return cellId;
-
-                depth--;
-
-                cellId = cellId.Previous;
-            }
-        }
-    }
-}
\ No newline at end of file
diff --git a/PokemonGo.RocketAPI/Helpers/Utils.cs b/PokemonGo.RocketAPI/Helpers/Utils.cs
deleted file mode 100644
index 13727c2..0000000
--- a/PokemonGo.RocketAPI/Helpers/Utils.cs
+++ /dev/null
@@ -1,17 +0,0 @@
-#region
-
-using System;
-
-#endregion
-
-namespace PokemonGo.RocketAPI.Helpers
-{
-    public class Utils
-    {
-        public static ulong FloatAsUlong(double value)
-        {
-            var bytes = BitConverter.GetBytes(value);
-            return BitConverter.ToUInt64(bytes, 0);
-        }
-    }
-}
\ No newline at end of file
diff --git a/PokemonGo.RocketAPI/ISettings.cs b/PokemonGo.RocketAPI/ISettings.cs
deleted file mode 100644
index 011ca9e..0000000
--- a/PokemonGo.RocketAPI/ISettings.cs
+++ /dev/null
@@ -1,41 +0,0 @@
-#region
-
-using PokemonGo.RocketAPI.Enums;
-using System.Collections.Generic;
-using PokemonGo.RocketAPI.GeneratedCode;
-
-#endregion
-
-
-namespace PokemonGo.RocketAPI
-{
-    public interface ISettings
-    {
-        AuthType AuthType { get; }
-        double DefaultLatitude { get; }
-        double DefaultLongitude { get; }
-        double DefaultAltitude { get; }
-        string PtcPassword { get; }
-        string PtcUsername { get; }
-        float KeepMinIVPercentage { get; }
-        int KeepMinCP { get; }
-        double WalkingSpeedInKilometerPerHour { get; }
-        bool EvolveAllPokemonWithEnoughCandy { get; }
-        bool TransferDuplicatePokemon { get; }
-        bool UsePokemonToNotCatchFilter { get; }
-        int KeepMinDuplicatePokemon { get; }
-        bool PrioritizeIVOverCP { get; }
-        int MaxTravelDistanceInMeters { get; }
-
-        bool UseGPXPathing { get; }
-        string GPXFile { get; }
-
-        ICollection<KeyValuePair<ItemId, int>> ItemRecycleFilter { get; }
-
-        ICollection<PokemonId> PokemonsToEvolve { get; }
-
-        ICollection<PokemonId> PokemonsNotToTransfer { get; }
-
-        ICollection<PokemonId> PokemonsNotToCatch { get; }
-    }
-}
\ No newline at end of file
diff --git a/PokemonGo.RocketAPI/Logging/Logger.cs b/PokemonGo.RocketAPI/Logging/Logger.cs
deleted file mode 100644
index 0735538..0000000
--- a/PokemonGo.RocketAPI/Logging/Logger.cs
+++ /dev/null
@@ -1,128 +0,0 @@
-#region
-
-using System;
-using System.IO;
-
-#endregion
-
-
-namespace PokemonGo.RocketAPI.Logging
-{
-    /// <summary>
-    /// Generic logger which can be used across the projects.
-    /// Logger should be set to properly log.
-    /// </summary>
-    public class Logger
-    {
-        static string _currentFile = string.Empty;
-        static string path = Directory.GetCurrentDirectory() + "\\Logs\\";
-
-        //private static Logger _logger;
-
-        /// <summary>
-        /// Set the logger. All future requests to <see cref="Write(string, LogLevel)"/> will use that logger, any old will be unset.
-        /// </summary>
-        /// <param name="logger"></param>
-        public static void SetLogger()
-		{
-            if (!Directory.Exists(path))
-            {
-                DirectoryInfo di = Directory.CreateDirectory(path);
-            }
-            _currentFile = DateTime.Now.ToString("yyyy-MM-dd - HH.mm.ss");
-            Log($"Initializing Rocket logger @ {DateTime.Now}...");
-        }
-
-        /// <summary>
-        ///     Log a specific message to the logger setup by <see cref="SetLogger(ILogger)" /> .
-        /// </summary>
-        /// <param name="message">The message to log.</param>
-        /// <param name="level">Optional level to log. Default <see cref="LogLevel.Info" />.</param>
-        /// <param name="color">Optional. Default is automatic color.</param>
-        public static void Write(string message, LogLevel level = LogLevel.None, ConsoleColor color = ConsoleColor.White)
-        {
-            switch (level)
-            {
-                case LogLevel.Info:
-                    System.Console.ForegroundColor = ConsoleColor.DarkGreen;
-                    System.Console.WriteLine($"[{DateTime.Now.ToString("HH:mm:ss")}] (INFO) {message}");
-                    break;
-                case LogLevel.Warning:
-                    System.Console.ForegroundColor = ConsoleColor.DarkYellow;
-                    System.Console.WriteLine($"[{DateTime.Now.ToString("HH:mm:ss")}] (ATTENTION) {message}");
-                    break;
-                case LogLevel.Error:
-                    System.Console.ForegroundColor = ConsoleColor.Red;
-                    System.Console.WriteLine($"[{DateTime.Now.ToString("HH:mm:ss")}] (ERROR) {message}");
-                    break;
-                case LogLevel.Debug:
-                    System.Console.ForegroundColor = ConsoleColor.Gray;
-                    System.Console.WriteLine($"[{DateTime.Now.ToString("HH:mm:ss")}] (DEBUG) {message}");
-                    break;
-                case LogLevel.Navigation:
-                    System.Console.ForegroundColor = ConsoleColor.DarkCyan;
-                    System.Console.WriteLine($"[{DateTime.Now.ToString("HH:mm:ss")}] (NAVIGATION) {message}");
-                    break;
-                case LogLevel.Pokestop:
-                    System.Console.ForegroundColor = ConsoleColor.Cyan;
-                    System.Console.WriteLine($"[{DateTime.Now.ToString("HH:mm:ss")}] (POKESTOP) {message}");
-                    break;
-                case LogLevel.Pokemon:
-                    System.Console.ForegroundColor = ConsoleColor.Yellow;
-                    System.Console.WriteLine($"[{DateTime.Now.ToString("HH:mm:ss")}] (PKMN) {message}");
-                    break;
-                case LogLevel.Transfer:
-                    System.Console.ForegroundColor = ConsoleColor.White;
-                    System.Console.WriteLine($"[{DateTime.Now.ToString("HH:mm:ss")}] (TRANSFER) {message}");
-                    break;
-                case LogLevel.Evolve:
-                    System.Console.ForegroundColor = ConsoleColor.White;
-                    System.Console.WriteLine($"[{DateTime.Now.ToString("HH:mm:ss")}] (EVOLVE) {message}");
-                    break;
-                case LogLevel.Berry:
-                    System.Console.ForegroundColor = ConsoleColor.White;
-                    System.Console.WriteLine($"[{DateTime.Now.ToString("HH:mm:ss")}] (BERRY) {message}");
-                    break;
-                case LogLevel.Recycling:
-                    System.Console.ForegroundColor = ConsoleColor.DarkMagenta;
-                    System.Console.WriteLine($"[{DateTime.Now.ToString("HH:mm:ss")}] (RECYCLING) {message}");
-                    break;
-                case LogLevel.None:
-                    System.Console.ForegroundColor = color;
-                    System.Console.WriteLine($"[{DateTime.Now.ToString("HH:mm:ss")}] {message}");
-                    break;
-                default:
-                    System.Console.ForegroundColor = ConsoleColor.White;
-                    System.Console.WriteLine($"[{DateTime.Now.ToString("HH:mm:ss")}] {message}");
-                    break;
-            }
-            Log(string.Concat($"[{DateTime.Now.ToString("HH:mm:ss")}] ", message));
-        }
-
-        private static void Log(string message)
-        {
-            // maybe do a new log rather than appending?
-            using (var log = File.AppendText(path + _currentFile + ".txt"))
-            {
-                log.WriteLine(message);
-                log.Flush();
-            }
-        }
-    }
-
-    public enum LogLevel
-    {
-        None = 0,
-        Info = 1,
-        Warning = 2,
-        Error = 3,
-        Debug = 4,
-        Navigation = 5,
-        Pokestop = 6,
-        Pokemon = 7,
-        Transfer = 8,
-        Evolve = 9,
-        Berry = 10,
-        Recycling = 11
-    }
-}
\ No newline at end of file
diff --git a/PokemonGo.RocketAPI/Login/GoogleLogin.cs b/PokemonGo.RocketAPI/Login/GoogleLogin.cs
deleted file mode 100644
index 7bc0473..0000000
--- a/PokemonGo.RocketAPI/Login/GoogleLogin.cs
+++ /dev/null
@@ -1,113 +0,0 @@
-#region
-
-using System;
-using System.Collections.Generic;
-using System.Diagnostics;
-using System.Threading;
-using System.Threading.Tasks;
-using System.Windows.Forms;
-using PokemonGo.RocketAPI.Helpers;
-using PokemonGo.RocketAPI.Logging;
-
-#endregion
-
-namespace PokemonGo.RocketAPI.Login
-{
-    public static class GoogleLogin
-    {
-        private const string OauthTokenEndpoint = "https://www.googleapis.com/oauth2/v4/token";
-        private const string OauthEndpoint = "https://accounts.google.com/o/oauth2/device/code";
-        private const string ClientId = "848232511240-73ri3t7plvk96pj4f85uj8otdat2alem.apps.googleusercontent.com";
-        private const string ClientSecret = "NCjF1TLi2CcY6t5mt0ZveuL7";
-
-        /// <summary>
-        ///     Gets the access token from Google
-        /// </summary>
-        /// <param name="deviceCode"></param>
-        /// <returns>tokenResponse</returns>
-        public static async Task<TokenResponseModel> GetAccessToken(DeviceCodeModel deviceCode)
-        {
-            //Poll until user submitted code..
-            TokenResponseModel tokenResponse;
-            do
-            {
-                await Task.Delay(2000);
-                tokenResponse = await PollSubmittedToken(deviceCode.device_code);
-            } while (tokenResponse.access_token == null || tokenResponse.refresh_token == null);
-
-            return tokenResponse;
-        }
-
-        public static async Task<TokenResponseModel> GetAccessToken(string refreshToken)
-        {
-            return await HttpClientHelper.PostFormEncodedAsync<TokenResponseModel>(OauthTokenEndpoint,
-                new KeyValuePair<string, string>("access_type", "offline"),
-                new KeyValuePair<string, string>("client_id", ClientId),
-                new KeyValuePair<string, string>("client_secret", ClientSecret),
-                new KeyValuePair<string, string>("refresh_token", refreshToken),
-                new KeyValuePair<string, string>("grant_type", "refresh_token"),
-                new KeyValuePair<string, string>("scope", "openid email https://www.googleapis.com/auth/userinfo.email"));
-        }
-
-        public static async Task<DeviceCodeModel> GetDeviceCode()
-        {
-            var deviceCode = await HttpClientHelper.PostFormEncodedAsync<DeviceCodeModel>(OauthEndpoint,
-                new KeyValuePair<string, string>("client_id", ClientId),
-                new KeyValuePair<string, string>("scope", "openid email https://www.googleapis.com/auth/userinfo.email"));
-
-            try
-            {
-                Logger.Write("Google Device Code copied to clipboard");
-                Thread.Sleep(2000);
-                Process.Start(@"http://www.google.com/device");
-                var thread = new Thread(() => Clipboard.SetText(deviceCode.user_code)); //Copy device code
-                thread.SetApartmentState(ApartmentState.STA); //Set the thread to STA
-                thread.Start();
-                thread.Join();
-            }
-            catch (Exception)
-            {
-                Logger.Write("Couldnt copy to clipboard, do it manually", LogLevel.Warning);
-                Logger.Write($"Goto: http://www.google.com/device & enter {deviceCode.user_code}", LogLevel.Warning);
-            }
-
-            return deviceCode;
-        }
-
-        private static async Task<TokenResponseModel> PollSubmittedToken(string deviceCode)
-        {
-            return await HttpClientHelper.PostFormEncodedAsync<TokenResponseModel>(OauthTokenEndpoint,
-                new KeyValuePair<string, string>("client_id", ClientId),
-                new KeyValuePair<string, string>("client_secret", ClientSecret),
-                new KeyValuePair<string, string>("code", deviceCode),
-                new KeyValuePair<string, string>("grant_type", "http://oauth.net/grant_type/device/1.0"),
-                new KeyValuePair<string, string>("scope", "openid email https://www.googleapis.com/auth/userinfo.email"));
-        }
-
-        internal class ErrorResponseModel
-        {
-            public string error { get; set; }
-            public string error_description { get; set; }
-        }
-
-        public class TokenResponseModel
-        {
-            public string access_token { get; set; }
-            public string token_type { get; set; }
-            public int expires_in { get; set; }
-            public string refresh_token { get; set; }
-            public string id_token { get; set; }
-        }
-
-
-        public class DeviceCodeModel
-        {
-            public string verification_url { get; set; }
-            public int expires_in { get; set; }
-            public int interval { get; set; }
-            public string device_code { get; set; }
-            public string user_code { get; set; }
-        }
-
-    }
-}
diff --git a/PokemonGo.RocketAPI/Login/PtcLogin.cs b/PokemonGo.RocketAPI/Login/PtcLogin.cs
deleted file mode 100644
index 58a2416..0000000
--- a/PokemonGo.RocketAPI/Login/PtcLogin.cs
+++ /dev/null
@@ -1,83 +0,0 @@
-#region
-
-using System.Collections.Generic;
-using System.Net;
-using System.Net.Http;
-using System.Threading.Tasks;
-using System.Web;
-using PokemonGo.RocketAPI.Exceptions;
-using PokemonGo.RocketAPI.Helpers;
-
-#endregion
-
-namespace PokemonGo.RocketAPI.Login
-{
-    internal static class PtcLogin
-    {
-        public static async Task<string> GetAccessToken(string username, string password)
-        {
-            var handler = new HttpClientHandler
-            {
-                AutomaticDecompression = DecompressionMethods.GZip,
-                AllowAutoRedirect = false
-            };
-
-            using (var tempHttpClient = new HttpClient(handler))
-            {
-                //Get session cookie
-                var sessionResp = await tempHttpClient.GetAsync(Resources.PtcLoginUrl);
-                var data = await sessionResp.Content.ReadAsStringAsync();
-                if (data == null) throw new PtcOfflineException();
-
-                if (sessionResp.StatusCode == HttpStatusCode.InternalServerError)
-                    throw new PtcOfflineException();
-
-                var lt = JsonHelper.GetValue(data, "lt");
-                var executionId = JsonHelper.GetValue(data, "execution");
-
-                //Login
-                var loginResp = await tempHttpClient.PostAsync(Resources.PtcLoginUrl,
-                    new FormUrlEncodedContent(
-                        new[]
-                        {
-                            new KeyValuePair<string, string>("lt", lt),
-                            new KeyValuePair<string, string>("execution", executionId),
-                            new KeyValuePair<string, string>("_eventId", "submit"),
-                            new KeyValuePair<string, string>("username", username),
-                            new KeyValuePair<string, string>("password", password)
-                        }));
-
-                if (loginResp.Headers.Location == null)
-                {
-                    //This should be sufficient for catching AccountNotVerified exceptions
-                    if (loginResp.StatusCode == HttpStatusCode.OK && !loginResp.Headers.Contains("Set-Cookies"))
-                        throw new AccountNotVerifiedException();
-
-                    throw new PtcOfflineException();
-                }
-
-
-                var ticketId = HttpUtility.ParseQueryString(loginResp.Headers.Location.Query)["ticket"];
-                if (ticketId == null)
-                    throw new PtcOfflineException();
-
-                //Get tokenvar
-                var tokenResp = await tempHttpClient.PostAsync(Resources.PtcLoginOauth,
-                    new FormUrlEncodedContent(
-                        new[]
-                        {
-                            new KeyValuePair<string, string>("client_id", "mobile-app_pokemon-go"),
-                            new KeyValuePair<string, string>("redirect_uri",
-                                "https://www.nianticlabs.com/pokemongo/error"),
-                            new KeyValuePair<string, string>("client_secret",
-                                "w8ScCUXJQc6kXKw8FiOhd8Fixzht18Dq3PEVkUCP5ZPxtgyWsbTvWHFLm2wNY0JR"),
-                            new KeyValuePair<string, string>("grant_type", "refresh_token"),
-                            new KeyValuePair<string, string>("code", ticketId)
-                        }));
-
-                var tokenData = await tokenResp.Content.ReadAsStringAsync();
-                return HttpUtility.ParseQueryString(tokenData)["access_token"];
-            }
-        }
-    }
-}
\ No newline at end of file
diff --git a/PokemonGo.RocketAPI/PokemonGo.RocketAPI.csproj b/PokemonGo.RocketAPI/PokemonGo.RocketAPI.csproj
deleted file mode 100644
index ca8e6f1..0000000
--- a/PokemonGo.RocketAPI/PokemonGo.RocketAPI.csproj
+++ /dev/null
@@ -1,134 +0,0 @@
-<?xml version="1.0" encoding="utf-8"?>
-<Project ToolsVersion="14.0" DefaultTargets="Build" xmlns="http://schemas.microsoft.com/developer/msbuild/2003">
-  <Import Project="$(MSBuildExtensionsPath)\$(MSBuildToolsVersion)\Microsoft.Common.props" Condition="Exists('$(MSBuildExtensionsPath)\$(MSBuildToolsVersion)\Microsoft.Common.props')" />
-  <PropertyGroup>
-    <Configuration Condition=" '$(Configuration)' == '' ">Debug</Configuration>
-    <Platform Condition=" '$(Platform)' == '' ">AnyCPU</Platform>
-    <ProjectGuid>{05D2DA44-1B8E-4CF7-94ED-4D52451CD095}</ProjectGuid>
-    <OutputType>Library</OutputType>
-    <AppDesignerFolder>Properties</AppDesignerFolder>
-    <RootNamespace>PokemonGo.RocketAPI</RootNamespace>
-    <AssemblyName>Pokemon Go Rocket API</AssemblyName>
-    <TargetFrameworkVersion>v4.5</TargetFrameworkVersion>
-    <FileAlignment>512</FileAlignment>
-    <AssemblyInfoFilePath>Properties\AssemblyInfo.cs</AssemblyInfoFilePath>
-    <UpdateAssemblyVersion>True</UpdateAssemblyVersion>
-    <UpdateAssemblyFileVersion>False</UpdateAssemblyFileVersion>
-    <UpdateAssemblyInfoVersion>False</UpdateAssemblyInfoVersion>
-    <AssemblyVersionSettings>YearStamp.MonthStamp.DayStamp.Increment</AssemblyVersionSettings>
-    <PrimaryVersionType>AssemblyVersionAttribute</PrimaryVersionType>
-    <AssemblyVersion>2016.7.24.286</AssemblyVersion>
-  </PropertyGroup>
-  <PropertyGroup Condition=" '$(Configuration)|$(Platform)' == 'Debug|AnyCPU' ">
-    <DebugSymbols>true</DebugSymbols>
-    <DebugType>full</DebugType>
-    <Optimize>false</Optimize>
-    <OutputPath>bin\Debug\</OutputPath>
-    <DefineConstants>DEBUG;TRACE</DefineConstants>
-    <ErrorReport>prompt</ErrorReport>
-    <WarningLevel>4</WarningLevel>
-  </PropertyGroup>
-  <PropertyGroup Condition=" '$(Configuration)|$(Platform)' == 'Release|AnyCPU' ">
-    <DebugType>pdbonly</DebugType>
-    <Optimize>true</Optimize>
-    <OutputPath>bin\Release\</OutputPath>
-    <DefineConstants>TRACE</DefineConstants>
-    <ErrorReport>prompt</ErrorReport>
-    <WarningLevel>4</WarningLevel>
-  </PropertyGroup>
-  <ItemGroup>
-    <Reference Include="C5, Version=2.2.5073.27396, Culture=neutral, PublicKeyToken=282361b99ded7e8e, processorArchitecture=MSIL">
-      <HintPath>..\packages\C5.2.2.5073.27396\lib\portable-net40+sl50+wp80+win\C5.dll</HintPath>
-      <Private>True</Private>
-    </Reference>
-    <Reference Include="Google.Protobuf, Version=3.0.0.0, Culture=neutral, PublicKeyToken=a7d26565bac4d604, processorArchitecture=MSIL">
-      <HintPath>..\packages\Google.Protobuf.3.0.0-beta3\lib\dotnet\Google.Protobuf.dll</HintPath>
-      <Private>True</Private>
-    </Reference>
-    <Reference Include="Microsoft.Practices.EnterpriseLibrary.TransientFaultHandling, Version=6.0.0.0, Culture=neutral, PublicKeyToken=31bf3856ad364e35, processorArchitecture=MSIL">
-      <HintPath>..\packages\EnterpriseLibrary.TransientFaultHandling.6.0.1304.0\lib\portable-net45+win+wp8\Microsoft.Practices.EnterpriseLibrary.TransientFaultHandling.dll</HintPath>
-      <Private>True</Private>
-    </Reference>
-    <Reference Include="Microsoft.Practices.EnterpriseLibrary.TransientFaultHandling.Data, Version=6.0.0.0, Culture=neutral, PublicKeyToken=31bf3856ad364e35, processorArchitecture=MSIL">
-      <HintPath>..\packages\EnterpriseLibrary.TransientFaultHandling.Data.6.0.1304.1\lib\NET45\Microsoft.Practices.EnterpriseLibrary.TransientFaultHandling.Data.dll</HintPath>
-      <Private>True</Private>
-    </Reference>
-    <Reference Include="Newtonsoft.Json, Version=9.0.0.0, Culture=neutral, PublicKeyToken=30ad4fe6b2a6aeed, processorArchitecture=MSIL">
-      <HintPath>..\packages\Newtonsoft.Json.9.0.1\lib\net45\Newtonsoft.Json.dll</HintPath>
-      <Private>True</Private>
-    </Reference>
-    <Reference Include="S2Geometry, Version=1.0.0.0, Culture=neutral, processorArchitecture=MSIL">
-      <HintPath>..\packages\S2Geometry.1.0.1\lib\portable-net45+wp8+win8\S2Geometry.dll</HintPath>
-      <Private>True</Private>
-    </Reference>
-    <Reference Include="System" />
-    <Reference Include="System.Configuration" />
-    <Reference Include="System.Core" />
-    <Reference Include="System.Net.Http.Formatting, Version=5.2.3.0, Culture=neutral, PublicKeyToken=31bf3856ad364e35, processorArchitecture=MSIL">
-      <HintPath>..\packages\Microsoft.AspNet.WebApi.Client.5.2.3\lib\net45\System.Net.Http.Formatting.dll</HintPath>
-      <Private>True</Private>
-    </Reference>
-    <Reference Include="System.VarintBitConverter, Version=1.0.0.0, Culture=neutral, processorArchitecture=MSIL">
-      <HintPath>..\packages\VarintBitConverter.1.0.0.0\lib\Net40\System.VarintBitConverter.dll</HintPath>
-      <Private>True</Private>
-    </Reference>
-    <Reference Include="System.Web" />
-    <Reference Include="System.Windows.Forms" />
-    <Reference Include="System.Xml.Linq" />
-    <Reference Include="System.Data.DataSetExtensions" />
-    <Reference Include="Microsoft.CSharp" />
-    <Reference Include="System.Data" />
-    <Reference Include="System.Net.Http" />
-    <Reference Include="System.Xml" />
-  </ItemGroup>
-  <ItemGroup>
-    <Compile Include="Enums\AuthType.cs" />
-    <Compile Include="Enums\MiscEnums.cs" />
-    <Compile Include="Enums\RequestType.cs" />
-    <Compile Include="Exceptions\AccessTokenExpiredException.cs" />
-    <Compile Include="Exceptions\AccountNotVerifiedException.cs" />
-    <Compile Include="Exceptions\InvalidResponseException.cs" />
-    <Compile Include="Exceptions\PtcOfflineException.cs" />
-    <Compile Include="Extensions\DateTimeExtensions.cs" />
-    <Compile Include="GeneratedCode\AllEnum.cs" />
-    <Compile Include="GeneratedCode\Payloads.cs" />
-    <Compile Include="GeneratedCode\Request.cs" />
-    <Compile Include="GeneratedCode\Response.cs" />
-    <Compile Include="Helpers\Git.cs" />
-    <Compile Include="Helpers\HttpClientHelper.cs" />
-    <Compile Include="Helpers\JsonHelper.cs" />
-    <Compile Include="Helpers\ProtoHelper.cs" />
-    <Compile Include="Helpers\RetryHandler.cs" />
-    <Compile Include="Helpers\S2Helper.cs" />
-    <Compile Include="Helpers\Utils.cs" />
-    <Compile Include="ISettings.cs" />
-    <Compile Include="Logging\Logger.cs" />
-    <Compile Include="Login\GoogleLogin.cs" />
-    <Compile Include="Login\PtcLogin.cs" />
-    <None Include="app.config">
-      <SubType>Designer</SubType>
-    </None>
-    <Compile Include="Client.cs" />
-    <Compile Include="Extensions\HttpClientExtensions.cs" />
-    <Compile Include="Helpers\RandomHelper.cs" />
-    <Compile Include="Helpers\RequestBuilder.cs" />
-    <Compile Include="PokemonInfo.cs" />
-    <Compile Include="Resources.cs" />
-    <Compile Include="Properties\AssemblyInfo.cs" />
-  </ItemGroup>
-  <ItemGroup>
-    <None Include="packages.config" />
-    <None Include="Proto\AllEnum.proto" />
-    <None Include="Proto\Payloads.proto" />
-    <None Include="Proto\Response.proto" />
-    <None Include="Proto\Request.proto" />
-  </ItemGroup>
-  <Import Project="$(MSBuildToolsPath)\Microsoft.CSharp.targets" />
-  <!-- To modify your build process, add your task inside one of the targets below and uncomment it.
-       Other similar extension points exist, see Microsoft.Common.targets.
-  <Target Name="BeforeBuild">
-  </Target>
-  <Target Name="AfterBuild">
-  </Target>
-  -->
-</Project>
\ No newline at end of file
diff --git a/PokemonGo.RocketAPI/PokemonInfo.cs b/PokemonGo.RocketAPI/PokemonInfo.cs
deleted file mode 100644
index ad2eb19..0000000
--- a/PokemonGo.RocketAPI/PokemonInfo.cs
+++ /dev/null
@@ -1,321 +0,0 @@
-using System;
-using System.Collections.Generic;
-using System.Linq;
-using System.Text;
-using System.Threading.Tasks;
-using PokemonGo.RocketAPI.GeneratedCode;
-
-namespace PokemonGo.RocketAPI
-{
-    public struct BaseStats
-    {
-        public int BaseAttack, BaseDefense, BaseStamina;
-        public BaseStats(int baseStamina, int baseAttack, int baseDefense)
-        {
-            this.BaseAttack = baseAttack;
-            this.BaseDefense = baseDefense;
-            this.BaseStamina = baseStamina;
-        }
-        public override string ToString()
-        {
-            return (String.Format("({0} atk,{1} def,{2} sta)", BaseAttack, BaseDefense, BaseStamina));
-        }
-    }
-
-    public static class PokemonInfo
-    {
-        public static double CalculatePokemonPerfection(PokemonData poke)
-        {
-            if (poke.CpMultiplier + poke.AdditionalCpMultiplier == 0)
-                return (poke.IndividualAttack * 2 + poke.IndividualDefense + poke.IndividualStamina) / (4.0 * 15.0) * 100.0;
-
-            BaseStats baseStats = GetBaseStats(poke.PokemonId);
-            var max_cp = CalculateMaxCPMultiplier(poke);
-            var min_cp = CalculateMinCPMultiplier(poke);
-            var cur_cp = CalculateCPMultiplier(poke);
-
-            return ((cur_cp - min_cp) / (max_cp - min_cp)) * 100.0;
-        }
-
-        public static double CalculateMaxCPMultiplier(PokemonData poke)
-        {
-            BaseStats baseStats = GetBaseStats(poke.PokemonId);
-            return (baseStats.BaseAttack + 15) * Math.Sqrt(baseStats.BaseDefense + 15) * Math.Sqrt(baseStats.BaseStamina + 15);
-        }
-        public static double CalculateMinCPMultiplier(PokemonData poke)
-        {
-            BaseStats baseStats = GetBaseStats(poke.PokemonId);
-            return (baseStats.BaseAttack) * Math.Sqrt(baseStats.BaseDefense) * Math.Sqrt(baseStats.BaseStamina);
-        }
-        public static double CalculateCPMultiplier(PokemonData poke)
-        {
-            BaseStats baseStats = GetBaseStats(poke.PokemonId);
-            return (baseStats.BaseAttack + poke.IndividualAttack) * Math.Sqrt(baseStats.BaseDefense + poke.IndividualDefense) * Math.Sqrt(baseStats.BaseStamina + poke.IndividualStamina);
-        }
-
-        public static int CalculateMaxCP(PokemonData poke)
-        {
-            return Math.Max((int)Math.Floor(0.1 * CalculateMaxCPMultiplier(poke) * Math.Pow(poke.CpMultiplier + poke.AdditionalCpMultiplier, 2)), 10);
-        }
-        public static int CalculateMinCP(PokemonData poke)
-        {
-            return Math.Max((int)Math.Floor(0.1 * CalculateMinCPMultiplier(poke) * Math.Pow(poke.CpMultiplier + poke.AdditionalCpMultiplier, 2)), 10);
-        }
-        public static int CalculateCP(PokemonData poke)
-        {
-            return Math.Max((int)Math.Floor(0.1 * CalculateCPMultiplier(poke) * Math.Pow(poke.CpMultiplier + poke.AdditionalCpMultiplier, 2)), 10);
-        }
-
-        public static BaseStats GetBaseStats(PokemonId id)
-        {
-            switch ((int)id)
-            {
-                case 1: return new BaseStats(90, 126, 126);
-                case 2: return new BaseStats(120, 156, 158);
-                case 3: return new BaseStats(160, 198, 200);
-                case 4: return new BaseStats(78, 128, 108);
-                case 5: return new BaseStats(116, 160, 140);
-                case 6: return new BaseStats(156, 212, 182);
-                case 7: return new BaseStats(88, 112, 142);
-                case 8: return new BaseStats(118, 144, 176);
-                case 9: return new BaseStats(158, 186, 222);
-                case 10: return new BaseStats(90, 62, 66);
-                case 11: return new BaseStats(100, 56, 86);
-                case 12: return new BaseStats(120, 144, 144);
-                case 13: return new BaseStats(80, 68, 64);
-                case 14: return new BaseStats(90, 62, 82);
-                case 15: return new BaseStats(130, 144, 130);
-                case 16: return new BaseStats(80, 94, 90);
-                case 17: return new BaseStats(126, 126, 122);
-                case 18: return new BaseStats(166, 170, 166);
-                case 19: return new BaseStats(60, 92, 86);
-                case 20: return new BaseStats(110, 146, 150);
-                case 21: return new BaseStats(80, 102, 78);
-                case 22: return new BaseStats(130, 168, 146);
-                case 23: return new BaseStats(70, 112, 112);
-                case 24: return new BaseStats(120, 166, 166);
-                case 25: return new BaseStats(70, 124, 108);
-                case 26: return new BaseStats(120, 200, 154);
-                case 27: return new BaseStats(100, 90, 114);
-                case 28: return new BaseStats(150, 150, 172);
-                case 29: return new BaseStats(110, 100, 104);
-                case 30: return new BaseStats(140, 132, 136);
-                case 31: return new BaseStats(180, 184, 190);
-                case 32: return new BaseStats(92, 110, 94);
-                case 33: return new BaseStats(122, 142, 128);
-                case 34: return new BaseStats(162, 204, 170);
-                case 35: return new BaseStats(140, 116, 124);
-                case 36: return new BaseStats(190, 178, 178);
-                case 37: return new BaseStats(76, 106, 118);
-                case 38: return new BaseStats(146, 176, 194);
-                case 39: return new BaseStats(230, 98, 54);
-                case 40: return new BaseStats(280, 168, 108);
-                case 41: return new BaseStats(80, 88, 90);
-                case 42: return new BaseStats(150, 164, 164);
-                case 43: return new BaseStats(90, 134, 130);
-                case 44: return new BaseStats(120, 162, 158);
-                case 45: return new BaseStats(150, 202, 190);
-                case 46: return new BaseStats(70, 122, 120);
-                case 47: return new BaseStats(120, 162, 170);
-                case 48: return new BaseStats(120, 108, 118);
-                case 49: return new BaseStats(140, 172, 154);
-                case 50: return new BaseStats(20, 108, 86);
-                case 51: return new BaseStats(70, 148, 140);
-                case 52: return new BaseStats(80, 104, 94);
-                case 53: return new BaseStats(130, 156, 146);
-                case 54: return new BaseStats(100, 132, 112);
-                case 55: return new BaseStats(160, 194, 176);
-                case 56: return new BaseStats(80, 122, 96);
-                case 57: return new BaseStats(130, 178, 150);
-                case 58: return new BaseStats(110, 156, 110);
-                case 59: return new BaseStats(180, 230, 180);
-                case 60: return new BaseStats(80, 108, 98);
-                case 61: return new BaseStats(130, 132, 132);
-                case 62: return new BaseStats(180, 180, 202);
-                case 63: return new BaseStats(50, 110, 76);
-                case 64: return new BaseStats(80, 150, 112);
-                case 65: return new BaseStats(110, 186, 152);
-                case 66: return new BaseStats(140, 118, 96);
-                case 67: return new BaseStats(160, 154, 144);
-                case 68: return new BaseStats(180, 198, 180);
-                case 69: return new BaseStats(100, 158, 78);
-                case 70: return new BaseStats(130, 190, 110);
-                case 71: return new BaseStats(160, 222, 152);
-                case 72: return new BaseStats(80, 106, 136);
-                case 73: return new BaseStats(160, 170, 196);
-                case 74: return new BaseStats(80, 106, 118);
-                case 75: return new BaseStats(110, 142, 156);
-                case 76: return new BaseStats(160, 176, 198);
-                case 77: return new BaseStats(100, 168, 138);
-                case 78: return new BaseStats(130, 200, 170);
-                case 79: return new BaseStats(180, 110, 110);
-                case 80: return new BaseStats(190, 184, 198);
-                case 81: return new BaseStats(50, 128, 138);
-                case 82: return new BaseStats(100, 186, 180);
-                case 83: return new BaseStats(104, 138, 132);
-                case 84: return new BaseStats(70, 126, 96);
-                case 85: return new BaseStats(120, 182, 150);
-                case 86: return new BaseStats(130, 104, 138);
-                case 87: return new BaseStats(180, 156, 192);
-                case 88: return new BaseStats(160, 124, 110);
-                case 89: return new BaseStats(210, 180, 188);
-                case 90: return new BaseStats(60, 120, 112);
-                case 91: return new BaseStats(100, 196, 196);
-                case 92: return new BaseStats(60, 136, 82);
-                case 93: return new BaseStats(90, 172, 118);
-                case 94: return new BaseStats(120, 204, 156);
-                case 95: return new BaseStats(70, 90, 186);
-                case 96: return new BaseStats(120, 104, 140);
-                case 97: return new BaseStats(170, 162, 196);
-                case 98: return new BaseStats(60, 116, 110);
-                case 99: return new BaseStats(110, 178, 168);
-                case 100: return new BaseStats(80, 102, 124);
-                case 101: return new BaseStats(120, 150, 174);
-                case 102: return new BaseStats(120, 110, 132);
-                case 103: return new BaseStats(190, 232, 164);
-                case 104: return new BaseStats(100, 102, 150);
-                case 105: return new BaseStats(120, 140, 202);
-                case 106: return new BaseStats(100, 148, 172);
-                case 107: return new BaseStats(100, 138, 204);
-                case 108: return new BaseStats(180, 126, 160);
-                case 109: return new BaseStats(80, 136, 142);
-                case 110: return new BaseStats(130, 190, 198);
-                case 111: return new BaseStats(160, 110, 116);
-                case 112: return new BaseStats(210, 166, 160);
-                case 113: return new BaseStats(500, 40, 60);
-                case 114: return new BaseStats(130, 164, 152);
-                case 115: return new BaseStats(210, 142, 178);
-                case 116: return new BaseStats(60, 122, 100);
-                case 117: return new BaseStats(110, 176, 150);
-                case 118: return new BaseStats(90, 112, 126);
-                case 119: return new BaseStats(160, 172, 160);
-                case 120: return new BaseStats(60, 130, 128);
-                case 121: return new BaseStats(120, 194, 192);
-                case 122: return new BaseStats(80, 154, 196);
-                case 123: return new BaseStats(140, 176, 180);
-                case 124: return new BaseStats(130, 172, 134);
-                case 125: return new BaseStats(130, 198, 160);
-                case 126: return new BaseStats(130, 214, 158);
-                case 127: return new BaseStats(130, 184, 186);
-                case 128: return new BaseStats(150, 148, 184);
-                case 129: return new BaseStats(40, 42, 84);
-                case 130: return new BaseStats(190, 192, 196);
-                case 131: return new BaseStats(260, 186, 190);
-                case 132: return new BaseStats(96, 110, 110);
-                case 133: return new BaseStats(110, 114, 128);
-                case 134: return new BaseStats(260, 186, 168);
-                case 135: return new BaseStats(130, 192, 174);
-                case 136: return new BaseStats(130, 238, 178);
-                case 137: return new BaseStats(130, 156, 158);
-                case 138: return new BaseStats(70, 132, 160);
-                case 139: return new BaseStats(140, 180, 202);
-                case 140: return new BaseStats(60, 148, 142);
-                case 141: return new BaseStats(120, 190, 190);
-                case 142: return new BaseStats(160, 182, 162);
-                case 143: return new BaseStats(320, 180, 180);
-                case 144: return new BaseStats(180, 198, 242);
-                case 145: return new BaseStats(180, 232, 194);
-                case 146: return new BaseStats(180, 242, 194);
-                case 147: return new BaseStats(82, 128, 110);
-                case 148: return new BaseStats(122, 170, 152);
-                case 149: return new BaseStats(182, 250, 212);
-                case 150: return new BaseStats(212, 284, 202);
-                case 151: return new BaseStats(200, 220, 220);
-                default: return new BaseStats();
-            }
-        }
-
-        public static int GetPowerUpLevel(PokemonData poke)
-        {
-            return (int)(GetLevel(poke) * 2.0);
-        }
-        public static double GetLevel(PokemonData poke)
-        {
-
-            switch ((int)((poke.CpMultiplier + poke.AdditionalCpMultiplier) * 1000.0))
-            {
-                case 93: // 0.094 * 1000 = 93.99999678134
-                case 94: return 1;
-                case 135: return 1.5;
-                case 166: return 2;
-                case 192: return 2.5;
-                case 215: return 3;
-                case 236: return 3.5;
-                case 255: return 4;
-                case 273: return 4.5;
-                case 290: return 5;
-                case 306: return 5.5;
-                case 321: return 6;
-                case 335: return 6.5;
-                case 349: return 7;
-                case 362: return 7.5;
-                case 375: return 8;
-                case 387: return 8.5;
-                case 399: return 9;
-                case 411: return 9.5;
-                case 422: return 10;
-                case 432: return 15;
-                case 443: return 11;
-                case 453: return 11.5;
-                case 462: return 12;
-                case 472: return 12.5;
-                case 481: return 13;
-                case 490: return 13.5;
-                case 499: return 14;
-                case 508: return 14.5;
-                case 517: return 15;
-                case 525: return 15.5;
-                case 534: return 16;
-                case 542: return 16.5;
-                case 550: return 17;
-                case 558: return 17.5;
-                case 566: return 18;
-                case 574: return 18.5;
-                case 582: return 19;
-                case 589: return 19.5;
-                case 597: return 20;
-                case 604: return 25;
-                case 612: return 21;
-                case 619: return 21.5;
-                case 626: return 22;
-                case 633: return 22.5;
-                case 640: return 23;
-                case 647: return 23.5;
-                case 654: return 24;
-                case 661: return 24.5;
-                case 667: return 25;
-                case 674: return 25.5;
-                case 681: return 26;
-                case 687: return 26.5;
-                case 694: return 27;
-                case 700: return 27.5;
-                case 706: return 28;
-                case 713: return 28.5;
-                case 719: return 29;
-                case 725: return 29.5;
-                case 731: return 30;
-                case 734: return 35;
-                case 737: return 31;
-                case 740: return 31.5;
-                case 743: return 32;
-                case 746: return 32.5;
-                case 749: return 33;
-                case 752: return 33.5;
-                case 755: return 34;
-                case 758: return 34.5;
-                case 761: return 35;
-                case 764: return 35.5;
-                case 767: return 36;
-                case 770: return 36.5;
-                case 773: return 37;
-                case 776: return 37.5;
-                case 778: return 38;
-                case 781: return 38.5;
-                case 784: return 39;
-                case 787: return 39.5;
-                case 790: return 40;
-                default: return 0;
-            }
-        }
-    }
-}
\ No newline at end of file
diff --git a/PokemonGo.RocketAPI/Properties/AssemblyInfo.cs b/PokemonGo.RocketAPI/Properties/AssemblyInfo.cs
deleted file mode 100644
index 951128e..0000000
--- a/PokemonGo.RocketAPI/Properties/AssemblyInfo.cs
+++ /dev/null
@@ -1,36 +0,0 @@
-using System.Reflection;
-using System.Runtime.CompilerServices;
-using System.Runtime.InteropServices;
-
-// General Information about an assembly is controlled through the following
-// set of attributes. Change these attribute values to modify the information
-// associated with an assembly.
-[assembly: AssemblyTitle("Pokemon Go Rocket API")]
-[assembly: AssemblyDescription("")]
-[assembly: AssemblyConfiguration("")]
-[assembly: AssemblyCompany("")]
-[assembly: AssemblyProduct("Pokemon Go Rocket API")]
-[assembly: AssemblyCopyright("Copyright ©  2016")]
-[assembly: AssemblyTrademark("")]
-[assembly: AssemblyCulture("")]
-
-// Setting ComVisible to false makes the types in this assembly not visible
-// to COM components.  If you need to access a type in this assembly from
-// COM, set the ComVisible attribute to true on that type.
-[assembly: ComVisible(false)]
-
-// The following GUID is for the ID of the typelib if this project is exposed to COM
-[assembly: Guid("05d2da44-1b8e-4cf7-94ed-4d52451cd095")]
-
-// Version information for an assembly consists of the following four values:
-//
-//      Major Version
-//      Minor Version
-//      Build Number
-//      Revision
-//
-// You can specify all the values or you can default the Build and Revision Numbers
-// by using the '*' as shown below:
-// [assembly: AssemblyVersion("1.0.*")]
-[assembly: AssemblyVersion("2016.7.24.286")]
-[assembly: AssemblyFileVersion("1.0.0.0")]
diff --git a/PokemonGo.RocketAPI/Proto/AllEnum.proto b/PokemonGo.RocketAPI/Proto/AllEnum.proto
deleted file mode 100644
index 593fe9d..0000000
--- a/PokemonGo.RocketAPI/Proto/AllEnum.proto
+++ /dev/null
@@ -1,767 +0,0 @@
-syntax = "proto3";
-
-package AllEnum;
-option csharp_namespace = "PokemonGo.RocketAPI.GeneratedCode";
-
-enum RpcDirection {
-  UNKNOWN = 0;
-  RESPONSE = 1;
-  REQUEST = 2;
-}
-
-enum TeamColor {
-  NEUTRAL = 0;
-  BLUE = 1;
-  RED = 2;
-  YELLOW = 3;
-}
-
-
-enum RequestMethod {
-  METHOD_UNSET = 0;
-  PLAYER_UPDATE = 1;
-  GET_PLAYER = 2;
-  GET_INVENTORY = 4;
-  DOWNLOAD_SETTINGS = 5;
-  DOWNLOAD_ITEM_TEMPLATES = 6;
-  DOWNLOAD_REMOTE_CONFIG_VERSION = 7;
-  FORT_SEARCH = 101;
-  ENCOUNTER = 102;
-  CATCH_POKEMON = 103;
-  FORT_DETAILS = 104;
-  ITEM_USE = 105;
-  GET_MAP_OBJECTS = 106;
-  FORT_DEPLOY_POKEMON = 110;
-  FORT_RECALL_POKEMON = 111;
-  RELEASE_POKEMON = 112;
-  USE_ITEM_POTION = 113;
-  USE_ITEM_CAPTURE = 114;
-  USE_ITEM_FLEE = 115;
-  USE_ITEM_REVIVE = 116;
-  TRADE_SEARCH = 117;
-  TRADE_OFFER = 118;
-  TRADE_RESPONSE = 119;
-  TRADE_RESULT = 120;
-  GET_PLAYER_PROFILE = 121;
-  GET_ITEM_PACK = 122;
-  BUY_ITEM_PACK = 123;
-  BUY_GEM_PACK = 124;
-  EVOLVE_POKEMON = 125;
-  GET_HATCHED_EGGS = 126;
-  ENCOUNTER_TUTORIAL_COMPLETE = 127;
-  LEVEL_UP_REWARDS = 128;
-  CHECK_AWARDED_BADGES = 129;
-  USE_ITEM_GYM = 133;
-  GET_GYM_DETAILS = 134;
-  START_GYM_BATTLE = 135;
-  ATTACK_GYM = 136;
-  RECYCLE_INVENTORY_ITEM = 137;
-  COLLECT_DAILY_BONUS = 138;
-  USE_ITEM_XP_BOOST = 139;
-  USE_ITEM_EGG_INCUBATOR = 140;
-  USE_INCENSE = 141;
-  GET_INCENSE_POKEMON = 142;
-  INCENSE_ENCOUNTER = 143;
-  ADD_FORT_MODIFIER = 144;
-  DISK_ENCOUNTER = 145;
-  COLLECT_DAILY_DEFENDER_BONUS = 146;
-  UPGRADE_POKEMON = 147;
-  SET_FAVORITE_POKEMON = 148;
-  NICKNAME_POKEMON = 149;
-  EQUIP_BADGE = 150;
-  SET_CONTACT_SETTINGS = 151;
-  GET_ASSET_DIGEST = 300;
-  GET_DOWNLOAD_URLS = 301;
-  GET_SUGGESTED_CODENAMES = 401;
-  CHECK_CODENAME_AVAILABLE = 402;
-  CLAIM_CODENAME = 403;
-  SET_AVATAR = 404;
-  SET_PLAYER_TEAM = 405;
-  MARK_TUTORIAL_COMPLETE = 406;
-  LOAD_SPAWN_POINTS = 500;
-  ECHO = 666;
-  DEBUG_UPDATE_INVENTORY = 700;
-  DEBUG_DELETE_PLAYER = 701;
-  SFIDA_REGISTRATION = 800;
-  SFIDA_ACTION_LOG = 801;
-  SFIDA_CERTIFICATION = 802;
-  SFIDA_UPDATE = 803;
-  SFIDA_ACTION = 804;
-  SFIDA_DOWSER = 805;
-  SFIDA_CAPTURE = 806;
-}
-
-enum PokemonMove {
-  MOVE_UNSET = 0;
-  THUNDER_SHOCK = 1;
-  QUICK_ATTACK = 2;
-  SCRATCH = 3;
-  EMBER = 4;
-  VINE_WHIP = 5;
-  TACKLE = 6;
-  RAZOR_LEAF = 7;
-  TAKE_DOWN = 8;
-  WATER_GUN = 9;
-  BITE = 10;
-  POUND = 11;
-  DOUBLE_SLAP = 12;
-  WRAP = 13;
-  HYPER_BEAM = 14;
-  LICK = 15;
-  DARK_PULSE = 16;
-  SMOG = 17;
-  SLUDGE = 18;
-  METAL_CLAW = 19;
-  VICE_GRIP = 20;
-  FLAME_WHEEL = 21;
-  MEGAHORN = 22;
-  WING_ATTACK = 23;
-  FLAMETHROWER = 24;
-  SUCKER_PUNCH = 25;
-  DIG = 26;
-  LOW_KICK = 27;
-  CROSS_CHOP = 28;
-  PSYCHO_CUT = 29;
-  PSYBEAM = 30;
-  EARTHQUAKE = 31;
-  STONE_EDGE = 32;
-  ICE_PUNCH = 33;
-  HEART_STAMP = 34;
-  DISCHARGE = 35;
-  FLASH_CANNON = 36;
-  PECK = 37;
-  DRILL_PECK = 38;
-  ICE_BEAM = 39;
-  BLIZZARD = 40;
-  AIR_SLASH = 41;
-  HEAT_WAVE = 42;
-  TWINEEDLE = 43;
-  POISON_JAB = 44;
-  AERIAL_ACE = 45;
-  DRILL_RUN = 46;
-  PETAL_BLIZZARD = 47;
-  MEGA_DRAIN = 48;
-  BUG_BUZZ = 49;
-  POISON_FANG = 50;
-  NIGHT_SLASH = 51;
-  SLASH = 52;
-  BUBBLE_BEAM = 53;
-  SUBMISSION = 54;
-  KARATE_CHOP = 55;
-  LOW_SWEEP = 56;
-  AQUA_JET = 57;
-  AQUA_TAIL = 58;
-  SEED_BOMB = 59;
-  PSYSHOCK = 60;
-  ROCK_THROW = 61;
-  ANCIENT_POWER = 62;
-  ROCK_TOMB = 63;
-  ROCK_SLIDE = 64;
-  POWER_GEM = 65;
-  SHADOW_SNEAK = 66;
-  SHADOW_PUNCH = 67;
-  SHADOW_CLAW = 68;
-  OMINOUS_WIND = 69;
-  SHADOW_BALL = 70;
-  BULLET_PUNCH = 71;
-  MAGNET_BOMB = 72;
-  STEEL_WING = 73;
-  IRON_HEAD = 74;
-  PARABOLIC_CHARGE = 75;
-  SPARK = 76;
-  THUNDER_PUNCH = 77;
-  THUNDER = 78;
-  THUNDERBOLT = 79;
-  TWISTER = 80;
-  DRAGON_BREATH = 81;
-  DRAGON_PULSE = 82;
-  DRAGON_CLAW = 83;
-  DISARMING_VOICE = 84;
-  DRAINING_KISS = 85;
-  DAZZLING_GLEAM = 86;
-  MOONBLAST = 87;
-  PLAY_ROUGH = 88;
-  CROSS_POISON = 89;
-  SLUDGE_BOMB = 90;
-  SLUDGE_WAVE = 91;
-  GUNK_SHOT = 92;
-  MUD_SHOT = 93;
-  BONE_CLUB = 94;
-  BULLDOZE = 95;
-  MUD_BOMB = 96;
-  FURY_CUTTER = 97;
-  BUG_BITE = 98;
-  SIGNAL_BEAM = 99;
-  X_SCISSOR = 100;
-  FLAME_CHARGE = 101;
-  FLAME_BURST = 102;
-  FIRE_BLAST = 103;
-  BRINE = 104;
-  WATER_PULSE = 105;
-  SCALD = 106;
-  HYDRO_PUMP = 107;
-  PSYCHIC = 108;
-  PSYSTRIKE = 109;
-  ICE_SHARD = 110;
-  ICY_WIND = 111;
-  FROST_BREATH = 112;
-  ABSORB = 113;
-  GIGA_DRAIN = 114;
-  FIRE_PUNCH = 115;
-  SOLAR_BEAM = 116;
-  LEAF_BLADE = 117;
-  POWER_WHIP = 118;
-  SPLASH = 119;
-  ACID = 120;
-  AIR_CUTTER = 121;
-  HURRICANE = 122;
-  BRICK_BREAK = 123;
-  CUT = 124;
-  SWIFT = 125;
-  HORN_ATTACK = 126;
-  STOMP = 127;
-  HEADBUTT = 128;
-  HYPER_FANG = 129;
-  SLAM = 130;
-  BODY_SLAM = 131;
-  REST = 132;
-  STRUGGLE = 133;
-  SCALD_BLASTOISE = 134;
-  HYDRO_PUMP_BLASTOISE = 135;
-  WRAP_GREEN = 136;
-  WRAP_PINK = 137;
-  FURY_CUTTER_FAST = 200;
-  BUG_BITE_FAST = 201;
-  BITE_FAST = 202;
-  SUCKER_PUNCH_FAST = 203;
-  DRAGON_BREATH_FAST = 204;
-  THUNDER_SHOCK_FAST = 205;
-  SPARK_FAST = 206;
-  LOW_KICK_FAST = 207;
-  KARATE_CHOP_FAST = 208;
-  EMBER_FAST = 209;
-  WING_ATTACK_FAST = 210;
-  PECK_FAST = 211;
-  LICK_FAST = 212;
-  SHADOW_CLAW_FAST = 213;
-  VINE_WHIP_FAST = 214;
-  RAZOR_LEAF_FAST = 215;
-  MUD_SHOT_FAST = 216;
-  ICE_SHARD_FAST = 217;
-  FROST_BREATH_FAST = 218;
-  QUICK_ATTACK_FAST = 219;
-  SCRATCH_FAST = 220;
-  TACKLE_FAST = 221;
-  POUND_FAST = 222;
-  CUT_FAST = 223;
-  POISON_JAB_FAST = 224;
-  ACID_FAST = 225;
-  PSYCHO_CUT_FAST = 226;
-  ROCK_THROW_FAST = 227;
-  METAL_CLAW_FAST = 228;
-  BULLET_PUNCH_FAST = 229;
-  WATER_GUN_FAST = 230;
-  SPLASH_FAST = 231;
-  WATER_GUN_FAST_BLASTOISE = 232;
-  MUD_SLAP_FAST = 233;
-  ZEN_HEADBUTT_FAST = 234;
-  CONFUSION_FAST = 235;
-  POISON_STING_FAST = 236;
-  BUBBLE_FAST = 237;
-  FEINT_ATTACK_FAST = 238;
-  STEEL_WING_FAST = 239;
-  FIRE_FANG_FAST = 240;
-  ROCK_SMASH_FAST = 241;
-}
-
-enum ItemId {
-  ITEM_UNKNOWN = 0;
-  ITEM_POKE_BALL = 1;
-  ITEM_GREAT_BALL = 2;
-  ITEM_ULTRA_BALL = 3;
-  ITEM_MASTER_BALL = 4;
-  ITEM_POTION = 101;
-  ITEM_SUPER_POTION = 102;
-  ITEM_HYPER_POTION = 103;
-  ITEM_MAX_POTION = 104;
-  ITEM_REVIVE = 201;
-  ITEM_MAX_REVIVE = 202;
-  ITEM_LUCKY_EGG = 301;
-  ITEM_INCENSE_ORDINARY = 401;
-  ITEM_INCENSE_SPICY = 402;
-  ITEM_INCENSE_COOL = 403;
-  ITEM_INCENSE_FLORAL = 404;
-  ITEM_TROY_DISK = 501;
-  ITEM_X_ATTACK = 602;
-  ITEM_X_DEFENSE = 603;
-  ITEM_X_MIRACLE = 604;
-  ITEM_RAZZ_BERRY = 701;
-  ITEM_BLUK_BERRY = 702;
-  ITEM_NANAB_BERRY = 703;
-  ITEM_WEPAR_BERRY = 704;
-  ITEM_PINAP_BERRY = 705;
-  ITEM_SPECIAL_CAMERA = 801;
-  ITEM_INCUBATOR_BASIC_UNLIMITED = 901;
-  ITEM_INCUBATOR_BASIC = 902;
-  ITEM_POKEMON_STORAGE_UPGRADE = 1001;
-  ITEM_ITEM_STORAGE_UPGRADE = 1002;
-}
-
-enum InventoryUpgradeType {
-  UPGRADE_UNSET = 0;
-  INCREASE_ITEM_STORAGE = 1;
-  INCREASE_POKEMON_STORAGE = 2;
-}
-
-enum EggIncubatorType {
-  INCUBATOR_UNSET = 0;
-  INCUBATOR_DISTANCE = 1;
-}
-
-enum PokemonFamilyId {
-  FAMILY_UNSET = 0;
-  FAMILY_BULBASAUR = 1;
-  FAMILY_CHARMANDER = 4;
-  FAMILY_SQUIRTLE = 7;
-  FAMILY_CATERPIE = 10;
-  FAMILY_WEEDLE = 13;
-  FAMILY_PIDGEY = 16;
-  FAMILY_RATTATA = 19;
-  FAMILY_SPEAROW = 21;
-  FAMILY_EKANS = 23;
-  FAMILY_PIKACHU = 25;
-  FAMILY_SANDSHREW = 27;
-  FAMILY_NIDORAN = 29;
-  FAMILY_NIDORAN2 = 32;
-  FAMILY_CLEFAIRY = 35;
-  FAMILY_VULPIX = 37;
-  FAMILY_JIGGLYPUFF = 39;
-  FAMILY_ZUBAT = 41;
-  FAMILY_ODDISH = 43;
-  FAMILY_PARAS = 46;
-  FAMILY_VENONAT = 48;
-  FAMILY_DIGLETT = 50;
-  FAMILY_MEOWTH = 52;
-  FAMILY_PSYDUCK = 54;
-  FAMILY_MANKEY = 56;
-  FAMILY_GROWLITHE = 58;
-  FAMILY_POLIWAG = 60;
-  FAMILY_ABRA = 63;
-  FAMILY_MACHOP = 66;
-  FAMILY_BELLSPROUT = 69;
-  FAMILY_TENTACOOL = 72;
-  FAMILY_GEODUDE = 74;
-  FAMILY_PONYTA = 77;
-  FAMILY_SLOWPOKE = 79;
-  FAMILY_MAGNEMITE = 81;
-  FAMILY_FARFETCHD = 83;
-  FAMILY_DODUO = 84;
-  FAMILY_SEEL = 86;
-  FAMILY_GRIMER = 88;
-  FAMILY_SHELLDER = 90;
-  FAMILY_GASTLY = 92;
-  FAMILY_ONIX = 95;
-  FAMILY_DROWZEE = 96;
-  FAMILY_KRABBY = 98;
-  FAMILY_VOLTORB = 100;
-  FAMILY_EXEGGCUTE = 102;
-  FAMILY_CUBONE = 104;
-  FAMILY_HITMONLEE = 106;
-  FAMILY_HITMONCHAN = 107;
-  FAMILY_LICKITUNG = 108;
-  FAMILY_KOFFING = 109;
-  FAMILY_RHYHORN = 111;
-  FAMILY_CHANSEY = 113;
-  FAMILY_TANGELA = 114;
-  FAMILY_KANGASKHAN = 115;
-  FAMILY_HORSEA = 116;
-  FAMILY_GOLDEEN = 118;
-  FAMILY_STARYU = 120;
-  FAMILY_MR_MIME = 122;
-  FAMILY_SCYTHER = 123;
-  FAMILY_JYNX = 124;
-  FAMILY_ELECTABUZZ = 125;
-  FAMILY_MAGMAR = 126;
-  FAMILY_PINSIR = 127;
-  FAMILY_TAUROS = 128;
-  FAMILY_MAGIKARP = 129;
-  FAMILY_LAPRAS = 131;
-  FAMILY_DITTO = 132;
-  FAMILY_EEVEE = 133;
-  FAMILY_PORYGON = 137;
-  FAMILY_OMANYTE = 138;
-  FAMILY_KABUTO = 140;
-  FAMILY_AERODACTYL = 142;
-  FAMILY_SNORLAX = 143;
-  FAMILY_ARTICUNO = 144;
-  FAMILY_ZAPDOS = 145;
-  FAMILY_MOLTRES = 146;
-  FAMILY_DRATINI = 147;
-  FAMILY_MEWTWO = 150;
-  FAMILY_MEW = 151;
-}
-
-enum MapObjectsStatus {
-  UNSET_STATUS = 0;
-  SUCCESS = 1;
-  LOCATION_UNSET = 2;
-}
-
-enum FortType {
-  GYM = 0;
-  CHECKPOINT = 1;
-}
-
-enum PokemonId {
-  MISSINGNO = 0;
-  BULBASAUR = 1;
-  IVYSAUR = 2;
-  VENUSAUR = 3;
-  CHARMANDER = 4;
-  CHARMELEON = 5;
-  CHARIZARD = 6;
-  SQUIRTLE = 7;
-  WARTORTLE = 8;
-  BLASTOISE = 9;
-  CATERPIE = 10;
-  METAPOD = 11;
-  BUTTERFREE = 12;
-  WEEDLE = 13;
-  KAKUNA = 14;
-  BEEDRILL = 15;
-  PIDGEY = 16;
-  PIDGEOTTO = 17;
-  PIDGEOT = 18;
-  RATTATA = 19;
-  RATICATE = 20;
-  SPEAROW = 21;
-  FEAROW = 22;
-  EKANS = 23;
-  ARBOK = 24;
-  PIKACHU = 25;
-  RAICHU = 26;
-  SANDSHREW = 27;
-  SANDSLASH = 28;
-  NIDORAN_FEMALE = 29;
-  NIDORINA = 30;
-  NIDOQUEEN = 31;
-  NIDORAN_MALE = 32;
-  NIDORINO = 33;
-  NIDOKING = 34;
-  CLEFAIRY = 35;
-  CLEFABLE = 36;
-  VULPIX = 37;
-  NINETALES = 38;
-  JIGGLYPUFF = 39;
-  WIGGLYTUFF = 40;
-  ZUBAT = 41;
-  GOLBAT = 42;
-  ODDISH = 43;
-  GLOOM = 44;
-  VILEPLUME = 45;
-  PARAS = 46;
-  PARASECT = 47;
-  VENONAT = 48;
-  VENOMOTH = 49;
-  DIGLETT = 50;
-  DUGTRIO = 51;
-  MEOWTH = 52;
-  PERSIAN = 53;
-  PSYDUCK = 54;
-  GOLDUCK = 55;
-  MANKEY = 56;
-  PRIMEAPE = 57;
-  GROWLITHE = 58;
-  ARCANINE = 59;
-  POLIWAG = 60;
-  POLIWHIRL = 61;
-  POLIWRATH = 62;
-  ABRA = 63;
-  KADABRA = 64;
-  ALAKAZAM = 65;
-  MACHOP = 66;
-  MACHOKE = 67;
-  MACHAMP = 68;
-  BELLSPROUT = 69;
-  WEEPINBELL = 70;
-  VICTREEBEL = 71;
-  TENTACOOL = 72;
-  TENTACRUEL = 73;
-  GEODUDE = 74;
-  GRAVELER = 75;
-  GOLEM = 76;
-  PONYTA = 77;
-  RAPIDASH = 78;
-  SLOWPOKE = 79;
-  SLOWBRO = 80;
-  MAGNEMITE = 81;
-  MAGNETON = 82;
-  FARFETCHD = 83;
-  DODUO = 84;
-  DODRIO = 85;
-  SEEL = 86;
-  DEWGONG = 87;
-  GRIMER = 88;
-  MUK = 89;
-  SHELLDER = 90;
-  CLOYSTER = 91;
-  GASTLY = 92;
-  HAUNTER = 93;
-  GENGAR = 94;
-  ONIX = 95;
-  DROWZEE = 96;
-  HYPNO = 97;
-  KRABBY = 98;
-  KINGLER = 99;
-  VOLTORB = 100;
-  ELECTRODE = 101;
-  EXEGGCUTE = 102;
-  EXEGGUTOR = 103;
-  CUBONE = 104;
-  MAROWAK = 105;
-  HITMONLEE = 106;
-  HITMONCHAN = 107;
-  LICKITUNG = 108;
-  KOFFING = 109;
-  WEEZING = 110;
-  RHYHORN = 111;
-  RHYDON = 112;
-  CHANSEY = 113;
-  TANGELA = 114;
-  KANGASKHAN = 115;
-  HORSEA = 116;
-  SEADRA = 117;
-  GOLDEEN = 118;
-  SEAKING = 119;
-  STARYU = 120;
-  STARMIE = 121;
-  MR_MIME = 122;
-  SCYTHER = 123;
-  JYNX = 124;
-  ELECTABUZZ = 125;
-  MAGMAR = 126;
-  PINSIR = 127;
-  TAUROS = 128;
-  MAGIKARP = 129;
-  GYARADOS = 130;
-  LAPRAS = 131;
-  DITTO = 132;
-  EEVEE = 133;
-  VAPOREON = 134;
-  JOLTEON = 135;
-  FLAREON = 136;
-  PORYGON = 137;
-  OMANYTE = 138;
-  OMASTAR = 139;
-  KABUTO = 140;
-  KABUTOPS = 141;
-  AERODACTYL = 142;
-  SNORLAX = 143;
-  ARTICUNO = 144;
-  ZAPDOS = 145;
-  MOLTRES = 146;
-  DRATINI = 147;
-  DRAGONAIR = 148;
-  DRAGONITE = 149;
-  MEWTWO = 150;
-  MEW = 151;
-}
-
-enum FortSponsor {
-  UNSET_SPONSOR = 0;
-  MCDONALDS = 1;
-  POKEMON_STORE = 2;
-}
-
-enum FortRenderingType {
-  DEFAULT = 0;
-  INTERNAL_TEST = 1;
-}
-
-enum ItemType {
-        ITEM_TYPE_NONE = 0;
-        ITEM_TYPE_POKEBALL = 1;
-        ITEM_TYPE_POTION = 2;
-        ITEM_TYPE_REVIVE = 3;
-        ITEM_TYPE_MAP = 4;
-        ITEM_TYPE_BATTLE = 5;
-        ITEM_TYPE_FOOD = 6;
-        ITEM_TYPE_CAMERA = 7;
-        ITEM_TYPE_DISK = 8;
-        ITEM_TYPE_INCUBATOR = 9;
-        ITEM_TYPE_INCENSE = 10;
-        ITEM_TYPE_XP_BOOST = 11;
-        ITEM_TYPE_INVENTORY_UPGRADE = 12;
-}
-
-enum ItemCategory {
-  ITEM_CATEGORY_NONE = 0;
-  ITEM_CATEGORY_POKEBALL = 1;
-  ITEM_CATEGORY_FOOD = 2;
-  ITEM_CATEGORY_MEDICINE = 3;
-  ITEM_CATEGORY_BOOST = 4;
-  ITEM_CATEGORY_UTILITES = 5;
-  ITEM_CATEGORY_CAMERA = 6;
-  ITEM_CATEGORY_DISK = 7;
-  ITEM_CATEGORY_INCUBATOR = 8;
-  ITEM_CATEGORY_INCENSE = 9;
-  ITEM_CATEGORY_XP_BOOST = 10;
-  ITEM_CATEGORY_INVENTORY_UPGRADE = 11;
-}
-
-enum ItemEffect {
-        ITEM_EFFECT_NONE = 0;
-        ITEM_EFFECT_CAP_NO_FLEE = 1000;
-        ITEM_EFFECT_CAP_NO_MOVEMENT = 1002;
-        ITEM_EFFECT_CAP_NO_THREAT = 1003;
-        ITEM_EFFECT_CAP_TARGET_MAX = 1004;
-        ITEM_EFFECT_CAP_TARGET_SLOW = 1005;
-        ITEM_EFFECT_CAP_CHANCE_NIGHT = 1006;
-        ITEM_EFFECT_CAP_CHANCE_TRAINER = 1007;
-        ITEM_EFFECT_CAP_CHANCE_FIRST_THROW = 1008;
-        ITEM_EFFECT_CAP_CHANCE_LEGEND = 1009;
-        ITEM_EFFECT_CAP_CHANCE_HEAVY = 1010;
-        ITEM_EFFECT_CAP_CHANCE_REPEAT = 1011;
-        ITEM_EFFECT_CAP_CHANCE_MULTI_THROW = 1012;
-        ITEM_EFFECT_CAP_CHANCE_ALWAYS = 1013;
-        ITEM_EFFECT_CAP_CHANCE_SINGLE_THROW = 1014;
-}
-
-enum ActivityType {
-  ACTIVITY_UNKNOWN = 0;
-  ACTIVITY_CATCH_POKEMON = 1;
-  ACTIVITY_CATCH_LEGEND_POKEMON = 2;
-  ACTIVITY_FLEE_POKEMON = 3;
-  ACTIVITY_DEFEAT_FORT = 4;
-  ACTIVITY_EVOLVE_POKEMON = 5;
-  ACTIVITY_HATCH_EGG = 6;
-  ACTIVITY_WALK_KM = 7;
-  ACTIVITY_POKEDEX_ENTRY_NEW = 8;
-  ACTIVITY_CATCH_FIRST_THROW = 9;
-  ACTIVITY_CATCH_NICE_THROW = 10;
-  ACTIVITY_CATCH_GREAT_THROW = 11;
-  ACTIVITY_CATCH_EXCELLENT_THROW = 12;
-  ACTIVITY_CATCH_CURVEBALL = 13;
-  ACTIVITY_CATCH_FIRST_CATCH_OF_DAY = 14;
-  ACTIVITY_CATCH_MILESTONE = 15;
-  ACTIVITY_TRAIN_POKEMON = 16;
-  ACTIVITY_SEARCH_FORT = 17;
-  ACTIVITY_RELEASE_POKEMON = 18;
-  ACTIVITY_HATCH_EGG_SMALL_BONUS = 19;
-  ACTIVITY_HATCH_EGG_MEDIUM_BONUS = 20;
-  ACTIVITY_HATCH_EGG_LARGE_BONUS = 21;
-  ACTIVITY_DEFEAT_GYM_DEFENDER = 22;
-  ACTIVITY_DEFEAT_GYM_LEADER = 23;
-}
-
-enum BadgeType {
-  BADGE_UNSET = 0;
-  BADGE_TRAVEL_KM = 1;
-  BADGE_POKEDEX_ENTRIES = 2;
-  BADGE_CAPTURE_TOTAL = 3;
-  BADGE_DEFEATED_FORT = 4;
-  BADGE_EVOLVED_TOTAL = 5;
-  BADGE_HATCHED_TOTAL = 6;
-  BADGE_ENCOUNTERED_TOTAL = 7;
-  BADGE_POKESTOPS_VISITED = 8;
-  BADGE_UNIQUE_POKESTOPS = 9;
-  BADGE_POKEBALL_THROWN = 10;
-  BADGE_BIG_MAGIKARP = 11;
-  BADGE_DEPLOYED_TOTAL = 12;
-  BADGE_BATTLE_ATTACK_WON = 13;
-  BADGE_BATTLE_TRAINING_WON = 14;
-  BADGE_BATTLE_DEFEND_WON = 15;
-  BADGE_PRESTIGE_RAISED = 16;
-  BADGE_PRESTIGE_DROPPED = 17;
-  BADGE_TYPE_NORMAL = 18;
-  BADGE_TYPE_FIGHTING = 19;
-  BADGE_TYPE_FLYING = 20;
-  BADGE_TYPE_POISON = 21;
-  BADGE_TYPE_GROUND = 22;
-  BADGE_TYPE_ROCK = 23;
-  BADGE_TYPE_BUG = 24;
-  BADGE_TYPE_GHOST = 25;
-  BADGE_TYPE_STEEL = 26;
-  BADGE_TYPE_FIRE = 27;
-  BADGE_TYPE_WATER = 28;
-  BADGE_TYPE_GRASS = 29;
-  BADGE_TYPE_ELECTRIC = 30;
-  BADGE_TYPE_PSYCHIC = 31;
-  BADGE_TYPE_ICE = 32;
-  BADGE_TYPE_DRAGON = 33;
-  BADGE_TYPE_DARK = 34;
-  BADGE_TYPE_FAIRY = 35;
-  BADGE_SMALL_RATTATA = 36;
-  BADGE_PIKACHU = 37;
-}
-
-enum HoloIapItemCategory {
-        IAP_CATEGORY_NONE = 0;
-        IAP_CATEGORY_BUNDLE = 1;
-        IAP_CATEGORY_ITEMS = 2;
-        IAP_CATEGORY_UPGRADES = 3;
-        IAP_CATEGORY_POKECOINS = 4;
-}
-
-enum CameraInterpolation {
-        CAM_INTERP_CUT = 0;
-        CAM_INTERP_LINEAR = 1;
-        CAM_INTERP_SMOOTH = 2;
-        CAM_INTERP_SMOOTH_ROT_LINEAR_MOVE = 3;
-        CAM_INTERP_DEPENDS = 4;
-}
-
-enum CameraTarget {
-        CAM_TARGET_ATTACKER = 0;
-        CAM_TARGET_ATTACKER_EDGE = 1;
-        CAM_TARGET_ATTACKER_GROUND = 2;
-        CAM_TARGET_DEFENDER = 3;
-        CAM_TARGET_DEFENDER_EDGE = 4;
-        CAM_TARGET_DEFENDER_GROUND = 5;
-        CAM_TARGET_ATTACKER_DEFENDER = 6;
-        CAM_TARGET_ATTACKER_DEFENDER_EDGE = 7;
-        CAM_TARGET_DEFENDER_ATTACKER = 8;
-        CAM_TARGET_DEFENDER_ATTACKER_EDGE = 9;
-        CAM_TARGET_ATTACKER_DEFENDER_MIRROR = 11;
-        CAM_TARGET_SHOULDER_ATTACKER_DEFENDER = 12;
-        CAM_TARGET_SHOULDER_ATTACKER_DEFENDER_MIRROR = 13;
-        CAM_TARGET_ATTACKER_DEFENDER_WORLD = 14;
-}
-
-enum PokemonType {
-  POKEMON_TYPE_NONE = 0;
-  POKEMON_TYPE_NORMAL = 1;
-  POKEMON_TYPE_FIGHTING = 2;
-  POKEMON_TYPE_FLYING = 3;
-  POKEMON_TYPE_POISON = 4;
-  POKEMON_TYPE_GROUND = 5;
-  POKEMON_TYPE_ROCK = 6;
-  POKEMON_TYPE_BUG = 7;
-  POKEMON_TYPE_GHOST = 8;
-  POKEMON_TYPE_STEEL = 9;
-  POKEMON_TYPE_FIRE = 10;
-  POKEMON_TYPE_WATER = 11;
-  POKEMON_TYPE_GRASS = 12;
-  POKEMON_TYPE_ELECTRIC = 13;
-  POKEMON_TYPE_PSYCHIC = 14;
-  POKEMON_TYPE_ICE = 15;
-  POKEMON_TYPE_DRAGON = 16;
-  POKEMON_TYPE_DARK = 17;
-  POKEMON_TYPE_FAIRY = 18;
-}
-
-enum PokemonMovementType {
-  MOVEMENT_STATIC = 0;
-  MOVEMENT_JUMP = 1;
-  MOVEMENT_VERTICAL = 2;
-  MOVEMENT_PSYCHIC = 3;
-  MOVEMENT_ELECTRIC = 4;
-  MOVEMENT_FLYING = 5;
-  MOVEMENT_HOVERING = 6;
-}
-
-enum PokemonClass {
-  NORMAL = 0;
-  LEGENDARY = 1;
-  MYTHIC = 2;
-}
diff --git a/PokemonGo.RocketAPI/Proto/Payloads.proto b/PokemonGo.RocketAPI/Proto/Payloads.proto
deleted file mode 100644
index 3056709..0000000
--- a/PokemonGo.RocketAPI/Proto/Payloads.proto
+++ /dev/null
@@ -1,924 +0,0 @@
-syntax = "proto3";
-
-package PokemonGo.RocketAPI.GeneratedCode;
-
-import "AllEnum.proto";
-
-message GetPlayerResponse {
-    int32 unknown1 = 1;
-    Profile profile = 2;
-}
-
-message Profile {
-  int64 creation_time = 1;
-  string username = 2;
-  .AllEnum.TeamColor team = 5;
-  bytes tutorial = 7;
-  AvatarDetails avatar = 8;
-  int32 poke_storage = 9;
-  int32 item_storage = 10;
-  DailyBonus daily_bonus = 11;
-  bytes unknown12 = 12;
-  bytes unknown13 = 13;
-  repeated Currency currency = 14;
-}
-
-message DailyBonus {
-  int64 NextCollectTimestampMs = 1;
-  int64 NextDefenderBonusCollectTimestampMs = 2;
-}
-
-message Currency {
-  string type = 1;
-  int32 amount = 2;
-}
-
-message AvatarDetails {
-  int32 unknown2 = 2;
-  int32 unknown3 = 3;
-  int32 unknown9 = 9;
-  int32 unknown10 = 10;
-}
-
-message DownloadSettingsRequest {
-  string hash = 1;
-}
-
-message GetInventoryResponse {
-  bool success = 1;
-  InventoryDelta inventory_delta = 2;
-}
-
-message InventoryDelta {
-  int64 original_timestamp_ms = 1;
-  int64 new_timestamp_ms = 2;
-  repeated InventoryItem inventory_items = 3;
-}
-
-message InventoryItem {
-  int64 modified_timestamp_ms = 1;
-  int64 deleted_item_key = 2;
-  InventoryItemData inventory_item_data = 3;
-}
-
-message InventoryItemData {
-  PokemonData pokemon = 1;
-  Item item = 2;
-  PokedexEntry pokedex_entry = 3;
-  PlayerStats player_stats = 4;
-  PlayerCurrency player_currency = 5;
-  PlayerCamera player_camera = 6;
-  InventoryUpgrades inventory_upgrades = 7;
-  AppliedItems applied_items = 8;
-  EggIncubators egg_incubators = 9;
-  PokemonFamily pokemon_family = 10;
-}
-
-message RecycleInventoryItem {
-	.AllEnum.ItemId item_id = 1;
-	int32 count = 2;
-}
-
-message Pokemon {
-  int32 id = 1;
-  .AllEnum.PokemonId pokemon_type = 2;
-  int32 cp = 3;
-  int32 stamina = 4;
-  int32 stamina_max = 5;
-  .AllEnum.PokemonMove move_1 = 6;
-  .AllEnum.PokemonMove move_2 = 7;
-  int32 deployed_fort_id = 8;
-  string owner_name = 9;
-  bool is_egg = 10;
-  int32 egg_km_walked_target = 11;
-  int32 egg_km_walked_start = 12;
-  int32 origin = 14;
-  float height_m = 15;
-  float weight_kg = 16;
-  int32 individual_attack = 17;
-  int32 individual_defense = 18;
-  int32 individual_stamina = 19;
-  float cp_multiplier = 20;
-  int32 pokeball = 21;
-  uint64 captured_cell_id = 22;
-  int32 battles_attacked = 23;
-  int32 battles_defended = 24;
-  int32 egg_incubator_id = 25;
-  uint64 creation_time_ms = 26;
-  int32 num_upgrades = 27;
-  float additional_cp_multiplier = 28;
-  int32 favorite = 29;
-  string nickname = 30;
-  int32 from_fort = 31;
-}
-
-message Item {
-  .AllEnum.ItemType item = 1;
-  int32 count = 2;
-  bool unseen = 3;
-}
-
-message PokedexEntry {
-  int32 pokedex_entry_number = 1;
-  int32 times_encountered = 2;
-  int32 times_captured = 3;
-  int32 evolution_stone_pieces = 4;
-  int32 evolution_stones = 5;
-}
-
-message PlayerStats {
-  int32 level = 1;
-  int64 experience = 2;
-  int64 prev_level_xp = 3;
-  int64 next_level_xp = 4;
-  float km_walked = 5;
-  int32 pokemons_encountered = 6;
-  int32 unique_pokedex_entries = 7;
-  int32 pokemons_captured = 8;
-  int32 evolutions = 9;
-  int32 poke_stop_visits = 10;
-  int32 pokeballs_thrown = 11;
-  int32 eggs_hatched = 12;
-  int32 big_magikarp_caught = 13;
-  int32 battle_attack_won = 14;
-  int32 battle_attack_total = 15;
-  int32 battle_defended_won = 16;
-  int32 battle_training_won = 17;
-  int32 battle_training_total = 18;
-  int32 prestige_raised_total = 19;
-  int32 prestige_dropped_total = 20;
-  int32 pokemon_deployed = 21;
-  bytes pokemon_caught_by_type = 22; // TODO: repeated PokemonType ??
-  int32 small_rattata_caught = 23;
-}
-
-message PlayerCurrency {
-  int32 gems = 1;
-}
-
-message PlayerCamera {
-  bool is_default_camera = 1;
-}
-
-message InventoryUpgrades {
-  repeated InventoryUpgrade inventory_upgrades = 1;
-}
-
-message InventoryUpgrade {
-  .AllEnum.ItemType item = 1;
-  .AllEnum.InventoryUpgradeType upgrade_type = 2;
-  int32 additional_storage = 3;
-}
-
-message AppliedItems {
-  AppliedItem item = 4;
-}
-
-message AppliedItem {
-  .AllEnum.ItemId item_type = 1;
-  .AllEnum.ItemType item_type_category = 2;
-  int64 expire_ms = 3;
-  int64 applied_ms = 4;
-}
-
-message EggIncubators {
-  EggIncubator egg_incubator = 1;
-}
-
-message EggIncubator {
-  string item_id = 1;
-  .AllEnum.ItemType item_type = 2;
-  .AllEnum.EggIncubatorType incubator_type = 3;
-  int32 uses_remaining = 4;
-  int64 pokemon_id = 5; // TODO: Check if is PokemonType
-  double start_km_walked = 6;
-  double target_km_walked = 7;
-}
-
-message PokemonFamily {
-  .AllEnum.PokemonFamilyId family_id = 1;
-  int32 candy = 2;
-}
-
-message GetMapObjectsRequest {
-  bytes cell_id = 1;
-  bytes since_timestamp_ms = 2;
-  double latitude = 3;
-  double longitude = 4;
-}
-
-message GetMapObjectsResponse {
-  repeated MapCell map_cells = 1;
-  .AllEnum.MapObjectsStatus status = 2;
-}
-
-message MapCell {
-  // S2 geographic area that the cell covers (http://s2map.com/) (https://code.google.com/archive/p/s2-geometry-library/)
-  uint64 s2_cell_id = 1;
-  int64 current_timestamp_ms = 2;
-  repeated FortData forts = 3;
-  repeated SpawnPoint spawn_points = 4;
-  repeated string deleted_objects = 6;
-  bool is_truncated_list = 7;
-  repeated FortSummary fort_summaries = 8;
-  repeated SpawnPoint decimated_spawn_points = 9;
-
-  // Pokemon within 2 steps or less.
-  repeated WildPokemon wild_pokemons = 5;
-  // Pokemon within 1 step or none.
-  repeated MapPokemon catchable_pokemons = 10;
-  // Pokemon farther away than 2 steps, but still in the area.
-  repeated NearbyPokemon nearby_pokemons = 11;
-}
-
-message FortData {
-  string id = 1;
-  int64 last_modified_timestamp_ms = 2;
-  double latitude = 3;
-  double longitude = 4;
-  bool enabled = 8;
-  .AllEnum.FortType type = 9;
-
-  //// Fields related to gyms only
-
-  // Team that owns the gym
-  .AllEnum.TeamColor owned_by_team = 5;
-
-  // Highest CP Pokemon at the gym
-  .AllEnum.PokemonId guard_pokemon_id = 6;
-  int32 guard_pokemon_cp = 7;
-
-  // Prestigate / experience of the gym
-  int64 gym_points = 10;
-
-  // Whether someone is battling at the gym currently
-  bool is_in_battle = 11;
-
-  //// Fields related to pokestops only
-
-  // Timestamp when the pokestop can be activated again to get items / xp
-  int64 cooldown_complete_timestamp_ms = 14;
-
-  .AllEnum.FortSponsor sponsor = 15;
-  .AllEnum.FortRenderingType rendering_type = 16;
-
-  // Might represent the type of item applied to the pokestop, right now only lures can be applied
-  bytes active_fort_modifier = 12;
-  FortLureInfo lure_info = 13;
-}
-
-message FortLureInfo {
-  string fort_id = 1;
-  double unknown2 = 2;
-  .AllEnum.PokemonId active_pokemon_id = 3;
-  int64 lure_expires_timestamp_ms = 4;
-}
-
-message SpawnPoint {
-  double latitude = 2;
-  double longitude = 3;
-}
-
-message FortSummary {
-  int32 fort_summary_id = 1;
-  int32 last_modified_timestamp_ms = 2;
-  int32 latitude = 3;
-  int32 longitude = 4;
-}
-
-message WildPokemon {
-  fixed64 encounter_id = 1;
-  int64 last_modified_timestamp_ms = 2;
-  double latitude = 3;
-  double longitude = 4;
-  string spawnpoint_id = 5;
-  PokemonData pokemon_data = 7;
-  int32 time_till_hidden_ms = 11;
-}
-
-message PokemonData {
-  fixed64 id = 1;
-  .AllEnum.PokemonId pokemon_id = 2;
-  int32 cp = 3;
-  int32 stamina = 4;
-  int32 stamina_max = 5;
-  .AllEnum.PokemonMove move_1 = 6;
-  .AllEnum.PokemonMove move_2 = 7;
-  int32 deployed_fort_id = 8;
-  string owner_name = 9;
-  bool is_egg = 10;
-  int32 egg_km_walked_target = 11;
-  int32 egg_km_walked_start = 12;
-  int32 origin = 14;
-  float height_m = 15;
-  float weight_kg = 16;
-  int32 individual_attack = 17;
-  int32 individual_defense = 18;
-  int32 individual_stamina = 19;
-  float cp_multiplier = 20;
-  int32 pokeball = 21;
-  uint64 captured_cell_id = 22;
-  int32 battles_attacked = 23;
-  int32 battles_defended = 24;
-  int32 egg_incubator_id = 25;
-  uint64 creation_time_ms = 26;
-  int32 num_upgrades = 27;
-  float additional_cp_multiplier = 28;
-  int32 favorite = 29;
-  string nickname = 30;
-  int32 from_fort = 31;
-}
-
-message MapPokemon {
-  string spawnpoint_id = 1;
-  fixed64 encounter_id = 2;
-  .AllEnum.PokemonId pokemon_id = 3;
-  // After this timestamp, the pokemon will be gone.
-  int64 expiration_timestamp_ms = 4;
-  double latitude = 5;
-  double longitude = 6;
-}
-
-message NearbyPokemon {
-  .AllEnum.PokemonId pokemon_id = 1;
-  float distance_in_meters = 2;
-  fixed64 encounter_id = 3;
-}
-
-message DownloadSettingsResponse {
-  string error = 1;
-  string hash = 2;
-  GlobalSettings settings = 3;
-}
-
-message GlobalSettings {
-  FortSettings fort_settings = 2;
-  MapSettings map_settings = 3;
-  LevelSettings level_settings = 4;
-  InventorySettings inventory_settings = 5;
-  string minimum_client_version = 6;
-}
-
-message FortSettings {
-  double interaction_range_meters = 1;
-  int32 max_total_deployed_pokemon = 2;
-  int32 max_player_deployed_pokemon = 3;
-  double deploy_stamina_multiplier = 4;
-  double deploy_attack_multiplier = 5;
-  double far_interaction_range_meters = 6;
-}
-
-message MapSettings {
-  double pokemon_visible_range = 1;
-  double poke_nav_range_meters = 2;
-  double encounter_range_meters = 3;
-  float get_map_objects_min_refresh_seconds = 4;
-  float get_map_objects_max_refresh_seconds = 5;
-  float get_map_objects_min_distance_meters = 6;
-  string google_maps_api_key = 7;
-}
-
-message LevelSettings {
-  double trainer_cp_modifier = 2;
-  double trainer_difficulty_modifier = 3;
-}
-
-message InventorySettings {
-  int32 max_pokemon = 1;
-  int32 max_bag_items = 2;
-  int32 base_pokemon = 3;
-  int32 base_bag_items = 4;
-  int32 base_eggs = 5;
-}
-
-message PlayerUpdateRequest {
-  double latitude = 1;
-  double longitude = 2;
-}
-
-message PlayerUpdateResponse {
-  repeated WildPokemon wild_pokemons = 1;
-  repeated FortData forts = 2;
-  int32 forts_nearby = 3;
-}
-
-message DownloadItemTemplatesRequest {
-	// No message needed.
-}
-
-message DownloadItemTemplatesResponse {
-  bool success = 1;
-  repeated ItemTemplate item_templates = 2;
-  uint64 timestamp_ms = 3;
-
-  message ItemTemplate {
-    string template_id = 1;
-
-    PokemonSettings pokemon_settings = 2;
-    ItemSettings item_settings = 3;
-    MoveSettings move_settings = 4;
-    MoveSequenceSettings move_sequence_settings = 5;
-    TypeEffectiveSettings type_effective = 8;
-    BadgeSettings badge_settings = 10;
-    CameraSettings camera = 11;
-    PlayerLevelSettings player_level = 12;
-    GymLevelSettings gym_level = 13;
-    GymBattleSettings battle_settings = 14;
-    EncounterSettings encounter_settings = 15;
-    IapItemDisplay iap_item_display = 16;
-    IapSettings iap_settings = 17;
-    PokemonUpgradeSettings pokemon_upgrades = 18;
-    EquippedBadgeSettings equipped_badges = 19;
-  }
-}
-
-message UseItemCaptureRequest {
-  .AllEnum.ItemId item_id = 1;
-  fixed64 encounter_id = 2;
-  string spawn_point_guid = 3;
-}
-
-message UseItemCaptureResponse {
-  bool success = 1;
-  double item_capture_mult = 2;
-  double item_flee_mult = 3;
-  bool stop_movement = 4;
-  bool stop_attack = 5;
-  bool target_max = 6;
-  bool target_slow = 7;
-}
-
-message ReleasePokemonRequest {
-  fixed64 pokemon_id = 1;
-}
-
-message ReleasePokemonResponse {
-  Result result = 1;
-  int32 candy_awarded = 2;
-
-  enum Result {
-    UNSET = 0;
-    SUCCESS = 1;
-    POKEMON_DEPLOYED = 2;
-    FAILED = 3;
-    ERROR_POKEMON_IS_EGG = 4;
-  }
-}
-
-message GetHatchedEggsRequest {
-  // No message needed.
-}
-
-// Confirm if this is correct, I think that it should be "repeated HatchedEgg hatched_eggs" or something like that.
-message GetHatchedEggsResponse {
-  bool success = 1;
-  repeated uint64 pokemon_id = 2 [packed=true]; // Might be POGOProtos.Enums.Pokemon
-  repeated int32 experience_awarded = 3;
-  repeated int32 candy_awarded = 4;
-  repeated int32 stardust_awarded = 5;
-}
-
-message FortSearchRequest {
-  string fort_id = 1;
-  double player_latitude = 2;
-  double player_longitude = 3;
-  double fort_latitude = 4;
-  double fort_longitude = 5;
-}
-
-message FortSearchResponse {
-  Result result = 1;
-  repeated ItemAward items_awarded = 2;
-  int32 gems_awarded = 3;
-  PokemonData pokemon_data_egg = 4;
-  int32 experience_awarded = 5;
-  int64 cooldown_complete_timestamp_ms = 6;
-  int32 chain_hack_sequence_number = 7;
-
-  message ItemAward {
-    .AllEnum.ItemId item_id = 1;
-    int32 item_count = 2;
-  }
-
-  enum Result {
-    NO_RESULT_SET = 0;
-    SUCCESS = 1;
-    OUT_OF_RANGE = 2;
-    IN_COOLDOWN_PERIOD = 3;
-    INVENTORY_FULL = 4;
-  }
-}
-
-message FortDetailsRequest {
-  string fort_id = 1;
-  double latitude = 2;
-  double longitude = 3;
-}
-
-message FortDetailsResponse {
-  string fort_id = 1;
-  .AllEnum.TeamColor team_color = 2;
-  PokemonData pokemon_data = 3;
-  string name = 4;
-  repeated string image_urls = 5;
-  int32 fp = 6;
-  int32 stamina = 7;
-  int32 max_stamina = 8;
-  .AllEnum.FortType type = 9;
-  double latitude = 10;
-  double longitude = 11;
-  string description = 12;
-  repeated FortModifier modifiers = 13;
-}
-
-message FortModifier {
-  .AllEnum.ItemId item_id = 1;
-  int64 expiration_timestamp_ms = 2;
-  string deployer_player_codename = 3;
-}
-
-message EncounterRequest {
-  fixed64 encounter_id = 1;
-  string spawnpoint_id = 2;
-  double player_latitude = 3;
-  double player_longitude = 4;
-}
-
-message EncounterResponse {
-  WildPokemon wild_pokemon = 1;
-  Background background = 2;
-  Status status = 3;
-  CaptureProbability capture_probability = 4;
-
-  enum Background {
-    PARK = 0;
-    DESERT = 1;
-  }
-
-  enum Status {
-    ENCOUNTER_ERROR = 0;
-    ENCOUNTER_SUCCESS = 1;
-    ENCOUNTER_NOT_FOUND = 2;
-    ENCOUNTER_CLOSED = 3;
-    ENCOUNTER_POKEMON_FLED = 4;
-    ENCOUNTER_NOT_IN_RANGE = 5;
-    ENCOUNTER_ALREADY_HAPPENED = 6;
-    POKEMON_INVENTORY_FULL = 7;
-  }
-}
-
-message CaptureProbability {
-  repeated .AllEnum.ItemId pokeball_type = 1;
-  repeated float capture_probability = 2;
-  double reticle_difficulty_scale = 12;
-}
-
-message DiskEncounterRequest {
-  fixed64 encounter_id = 1;
-  string fort_id = 2;
-  double player_latitude = 3;
-  double player_longitude = 4;
-}
-
-message DiskEncounterResponse {
-  Result result = 1;
-  PokemonData pokemon_data = 2;
-  CaptureProbability capture_probability = 3;
-
-  enum Result {
-    UNKNOWN = 0;
-    SUCCESS = 1;
-    NOT_AVAILABLE = 2;
-    NOT_IN_RANGE = 3;
-    ENCOUNTER_ALREADY_FINISHED = 4;
-    POKEMON_INVENTORY_FULL = 5;
-  }
-}
-
-message CatchPokemonRequest {
-  fixed64 encounter_id = 1;
-  int32 pokeball = 2;
-  double normalized_reticle_size = 3;
-  string spawn_point_guid = 4;
-  bool hit_pokemon = 5;
-  double spin_modifier = 6;
-  double NormalizedHitPosition = 7;
-}
-
-message CatchPokemonResponse {
-  CatchStatus status = 1;
-  double miss_percent = 2;
-  uint64 captured_pokemon_id = 3;
-  CaptureScore scores = 4;
-
-  enum CatchStatus {
-    CATCH_ERROR = 0;
-    CATCH_SUCCESS = 1;
-    CATCH_ESCAPE = 2;
-    CATCH_FLEE = 3;
-    CATCH_MISSED = 4;
-  }
-}
-
-message CaptureScore {
-  repeated .AllEnum.ActivityType activity_type = 1;
-  repeated int32 xp = 2;
-  repeated int32 candy = 3;
-  repeated int32 stardust = 4;
-}
-
-message CheckAwardedBadgesRequest {
-	// No message needed.
-}
-
-// Confirm if this is correct, I think that it should be "repeated AwardedBadge awarded_badges" or something like that.
-message CheckAwardedBadgesResponse {
-  bool success = 1;
-  repeated .AllEnum.BadgeType awarded_badges = 2;
-  repeated int32 awarded_badge_levels = 3;
-}
-
-message EquippedBadgeSettings {
-  int64 equip_badge_cooldown_ms = 1;
-  repeated float catch_probability_bonus = 2;
-  repeated float flee_probability_bonus = 3;
-}
-
-message PokemonUpgradeSettings {
-  int32 upgrades_per_level = 1;
-  int32 allowed_levels_above_player = 2;
-  repeated int32 candy_cost = 3;
-  repeated int32 stardust_cost = 4;
-}
-
-message IapSettings {
-  int32 daily_bonus_coins = 1;
-  repeated int32 daily_defender_bonus_per_pokemon = 2;
-  int32 daily_defender_bonus_max_defenders = 3;
-  repeated string daily_defender_bonus_currency = 4;
-  int64 min_time_between_claims_ms = 5;
-  bool daily_bonus_enabled = 6;
-  bool daily_defender_bonus_enabled = 7;
-}
-
-message IapItemDisplay {
-  string sku = 1;
-  .AllEnum.HoloIapItemCategory category = 2;
-  int32 sort_order = 3;
-  repeated .AllEnum.ItemId item_ids = 4;
-  repeated int32 counts = 5;
-}
-
-message EncounterSettings {
-  float spin_bonus_threshold = 1;
-  float excellent_throw_threshold = 2;
-  float great_throw_threshold = 3;
-  float nice_throw_threshold = 4;
-  int32 milestone_threshold = 5;
-}
-
-message GymBattleSettings {
-  float energy_per_sec = 1;
-  float dodge_energy_cost = 2;
-  float retarget_seconds = 3;
-  float enemy_attack_interval = 4;
-  float attack_server_interval = 5;
-  float round_duration_seconds = 6;
-  float bonus_time_per_ally_seconds = 7;
-  int32 maximum_attackers_per_battle = 8;
-  float same_type_attack_bonus_multiplier = 9;
-  int32 maximum_energy = 10;
-  float energy_delta_per_health_lost = 11;
-  int32 dodge_duration_ms = 12;
-  int32 minimum_player_level = 13;
-  int32 swap_duration_ms = 14;
-}
-
-message GymLevelSettings {
-	repeated int32 required_experience = 1;
-	repeated int32 leader_slots = 2;
-	repeated int32 trainer_slots = 3;
-	repeated int32 search_roll_bonus = 4;
-}
-
-message PlayerLevelSettings {
-	repeated int32 rank_num = 1;
-	repeated int32 required_experience = 2;
-	repeated float cp_multiplier = 3;
-	int32 max_egg_player_level = 4;
-	int32 max_encounter_player_level = 5;
-}
-
-message CameraSettings {
-	string next_camera = 1;
-	repeated .AllEnum.CameraInterpolation interpolation = 2;
-	repeated .AllEnum.CameraTarget target_type = 3;
-	repeated float ease_in_speed = 4;
-	repeated float east_out_speed = 5;
-	repeated float duration_seconds = 6;
-	repeated float wait_seconds = 7;
-	repeated float transition_seconds = 8;
-	repeated float angle_degree = 9;
-	repeated float angle_offset_degree = 10;
-	repeated float pitch_degree = 11;
-	repeated float pitch_offset_degree = 12;
-	repeated float roll_degree = 13;
-	repeated float distance_meters = 14;
-	repeated float height_percent = 15;
-	repeated float vert_ctr_ratio = 16;
-}
-
-message BadgeSettings {
-  .AllEnum.BadgeType badge_type = 1;
-  int32 badge_rank = 2;
-  repeated int32 targets = 3;
-}
-
-message TypeEffectiveSettings {
-  repeated float attack_scalar = 1;
-  .AllEnum.PokemonType attack_type = 2;
-}
-
-message MoveSequenceSettings {
-  repeated string sequence = 1;
-}
-
-message MoveSettings {
-  .AllEnum.PokemonMovementType movement_id = 1;
-  int32 animation_id = 2;
-  .AllEnum.PokemonType pokemon_type = 3;
-  float power = 4;
-  float accuracy_chance = 5;
-  float critical_chance = 6;
-  float heal_scalar = 7;
-  float stamina_loss_scalar = 8;
-  int32 trainer_level_min = 9;
-  int32 trainer_level_max = 10;
-  string vfx_name = 11;
-  int32 duration_ms = 12;
-  int32 damage_window_start_ms = 13;
-  int32 damage_window_end_ms = 14;
-  int32 energy_delta = 15;
-}
-
-message PokemonSettings {
-  .AllEnum.PokemonId pokemon_id = 1;
-  float model_scale = 3;
-  .AllEnum.PokemonType type = 4;
-  .AllEnum.PokemonType type_2 = 5;
-  CameraAttributes camera = 6;
-  EncounterAttributes encounter = 7;
-  StatsAttributes stats = 8;
-  repeated .AllEnum.PokemonMove quick_moves = 9;
-  repeated .AllEnum.PokemonMove cinematic_moves = 10;
-  repeated float animation_time = 11;
-  repeated .AllEnum.PokemonId evolution_ids = 12;
-  int32 evolution_pips = 13;
-  .AllEnum.PokemonClass class = 14;
-  float pokedex_height_m = 15;
-  float pokedex_weight_kg = 16;
-  .AllEnum.PokemonId parent_pokemon_id = 17;
-  float height_std_dev = 18;
-  float weight_std_dev = 19;
-  float km_distance_to_hatch = 20;
-  .AllEnum.PokemonFamilyId family_id = 21;
-  int32 candy_to_evolve = 22;
-}
-
-message CameraAttributes {
-  float disk_radius_m = 1;
-  float cylinder_radius_m = 2;
-  float cylinder_height_m = 3;
-  float cylinder_ground_m = 4;
-  float shoulder_mode_scale = 5;
-}
-
-message EncounterAttributes {
-  float base_capture_rate = 1;
-  float base_flee_rate = 2;
-  float collision_radius_m = 3;
-  float collision_height_m = 4;
-  float collision_head_radius_m = 5;
-  .AllEnum.PokemonMovementType movement_type = 6;
-  float movement_timer_s = 7;
-  float jump_time_s = 8;
-  float attack_timer_s = 9;
-}
-
-message StatsAttributes {
-  int32 base_stamina = 1;
-  int32 base_attack = 2;
-  int32 base_defense = 3;
-  int32 dodge_energy_delta = 8;
-}
-
-message ItemSettings {
-  .AllEnum.ItemId item_id = 1;
-  .AllEnum.ItemType item_type = 2;
-  .AllEnum.ItemCategory category = 3;
-  float drop_freq = 4;
-  int32 drop_trainer_level = 5;
-
-  // One of the below attributes will be set in the response, the other will be null.
-
-  PokeballAttributes pokeball = 6;
-  PotionAttributes potion = 7;
-  ReviveAttributes revive = 8;
-  BattleAttributes battle = 9;
-  FoodAttributes food = 10;
-  InventoryUpgradeAttributes inventory_upgrade = 11;
-  ExperienceBoostAttributes xp_boost = 12;
-  IncenseAttributes incense = 13;
-  EggIncubatorAttributes egg_incubator = 14;
-  FortModifierAttributes fort_modifier = 15;
-}
-
-message BattleAttributes {
-  float sta_percent = 1;
-}
-
-message EggIncubatorAttributes {
-  .AllEnum.EggIncubatorType incubator_type = 1;
-  int32 uses = 2;
-  float distance_multiplier = 3;
-}
-
-message ExperienceBoostAttributes {
-  float xp_multiplier = 1;
-  int32 boost_duration_ms = 2;
-}
-
-message FoodAttributes {
-  repeated .AllEnum.ItemEffect item_effect = 1;
-  repeated float item_effect_percent = 2;
-  float growth_percent = 3;
-}
-
-message FortModifierAttributes {
-  int32 modifier_lifetime_seconds = 1;
-  int32 troy_disk_num_pokemon_spawned = 2;
-}
-
-message IncenseAttributes {
-  int32 incense_lifetime_seconds = 1;
-  repeated .AllEnum.PokemonType pokemon_type = 2;
-  float pokemon_incense_type_probability = 3;
-  int32 standing_time_between_encounters_seconds = 4;
-  int32 moving_time_between_encounter_seconds = 5;
-  int32 distance_required_for_shorter_interval_meters = 6;
-  int32 pokemon_attracted_length_sec = 7;
-}
-
-message InventoryUpgradeAttributes {
-  int32 additional_storage = 1;
-  .AllEnum.InventoryUpgradeType upgrade_type = 2;
-}
-
-message PokeballAttributes {
-  .AllEnum.ItemEffect item_effect = 1;
-  float capture_multi = 2;
-  float capture_multi_effect = 3;
-  float item_effect_mod = 4;
-}
-
-message PotionAttributes {
-  float sta_percent = 1;
-  int32 sta_amount = 2;
-}
-
-message ReviveAttributes {
-  float sta_percent = 1;
-}
-
-// POKEMON TRANSFER
-message TransferPokemon {
-    fixed64 PokemonId = 1;
-}
-
-message TransferPokemonOut {
-    int32 Status = 1;
-    int32 CandyAwarded = 2;
-}
-
-// EVOLVE
-message EvolvePokemon {
-    fixed64 PokemonId = 1;
-}
-
-
-message EvolvePokemonOut {
-    EvolvePokemonStatus Result = 1;
-    Pokemon EvolvedPokemon = 2;
-    int32 ExpAwarded = 3;
-    int32 CandyAwarded = 4;
-
-
-	enum EvolvePokemonStatus {
-		POKEMON_EVOLVED_UNSET = 0;
-		POKEMON_EVOLVED_SUCCESS = 1;
-		FAILED_POKEMON_MISSING = 2;
-		FAILED_INSUFFICIENT_RESOURCES = 3;
-		FAILED_POKEMON_CANNOT_EVOLVE = 4;
-		FAILED_POKEMON_IS_DEPLOYED = 5;
-	}
-}
\ No newline at end of file
diff --git a/PokemonGo.RocketAPI/Proto/Request.proto b/PokemonGo.RocketAPI/Proto/Request.proto
deleted file mode 100644
index 1f937bf..0000000
--- a/PokemonGo.RocketAPI/Proto/Request.proto
+++ /dev/null
@@ -1,108 +0,0 @@
-syntax = "proto3";
-
-package PokemonGo.RocketAPI.GeneratedCode;
-
-message Request {
-  int32 unknown1 = 1;
-  int64 rpc_id = 3;
-  repeated Requests requests = 4;
-  Unknown6 unknown6 = 6;
-  fixed64 latitude = 7;
-  fixed64 longitude = 8;
-  fixed64 altitude = 9;
-  AuthInfo auth = 10;
-  UnknownAuth unknownauth = 11;
-  int64 unknown12 = 12;
-
-
-  message UnknownAuth {
-    bytes unknown71 = 1;
-    int64 timestamp = 2;
-    bytes unknown73 = 3;
-  }
-
-  message Requests {
-    int32 type = 1;
-    bytes message = 2;
-  }
-
-  message Unknown3 {
-    string unknown4 = 1;
-  }
-
-  message Unknown6 {
-    int32 unknown1 = 1;
-    Unknown2 unknown2 = 2;
-
-    message Unknown2 {
-      bytes unknown1 = 1;
-    }
-
-  }
-
-  message AuthInfo {
-    string provider = 1;
-    JWT token = 2;
-
-    message JWT {
-      string contents = 1;
-      int32 unknown13  = 2;
-    }
-  }
-	message PlayerUpdateProto {
-	fixed64 Lat = 1;
-	fixed64 Lng = 2;
-	}
-
-	message MapObjectsRequest
-	{
-		bytes cellIds = 1;
-		bytes unknown14 = 2;
-		fixed64 latitude = 3;
-		fixed64 longitude = 4;
-	}
-
-	 message FortSearchRequest
-	{
-		bytes Id = 1;
-		fixed64 PlayerLatDegrees = 2;
-		fixed64 PlayerLngDegrees = 3;
-		fixed64 FortLatDegrees = 4;
-		fixed64 FortLngDegrees = 5;
-	}
-
-	message FortDetailsRequest
-	{
-  		bytes Id = 1;
-		fixed64 Latitude = 2;
-		fixed64 Longitude = 3;
-	}
-
-	 message EncounterRequest {
-		 fixed64 EncounterId = 1;
-		 string SpawnpointId = 2;
-		 fixed64 PlayerLatDegrees = 3;
-		 fixed64 PlayerLngDegrees = 4;
-	}
-
-	 message CatchPokemonRequest {
-		fixed64 EncounterId = 1;
-		int32 Pokeball = 2;
-		fixed64 NormalizedReticleSize = 3;
-		string SpawnPointGuid = 4;
-		int32 HitPokemon = 5;
-		fixed64 SpinModifier = 6;
-		fixed64 NormalizedHitPosition = 7;
-	}
-
-	message SettingsGuid
-	{
-		bytes guid = 1;
-	}
-
-	message Time
-	{
-		int64 time = 1;
-	}
-
-}
\ No newline at end of file
diff --git a/PokemonGo.RocketAPI/Proto/Response.proto b/PokemonGo.RocketAPI/Proto/Response.proto
deleted file mode 100644
index a15a0f0..0000000
--- a/PokemonGo.RocketAPI/Proto/Response.proto
+++ /dev/null
@@ -1,41 +0,0 @@
-syntax = "proto3";
-
-package PokemonGo.RocketAPI.GeneratedCode;
-
-message Response {
-  int32 unknown1 = 1;
-  int64 unknown2 = 2;
-  string api_url = 3;
-  Unknown6 unknown6 = 6;
-  Auth auth = 7;
-  repeated bytes payload = 100;
-  string errorMessage = 101;
-
-  message Unknown6 {
-    int32 unknown1 = 1;
-    Unknown2 unknown2 = 2;
-
-    message Unknown2 {
-      bytes unknown1 = 1;
-    }
-
-  }
-
-  message Auth {
-    bytes unknown71 = 1;
-    int64 timestamp = 2;
-    bytes unknown73 = 3;
-  }
-
-  message RecycleInventoryItemResponse {
-	Result result = 1;
-	int32 new_count = 2;
-
-	enum Result {
-		UNSET = 0;
-		SUCCESS = 1;
-		ERROR_NOT_ENOUGH_COPIES = 2;
-		ERROR_CANNOT_RECYCLE_INCUBATORS = 3;
-	}
-}
-}
\ No newline at end of file
diff --git a/PokemonGo.RocketAPI/Resources.cs b/PokemonGo.RocketAPI/Resources.cs
deleted file mode 100644
index 8647a2d..0000000
--- a/PokemonGo.RocketAPI/Resources.cs
+++ /dev/null
@@ -1,17 +0,0 @@
-#region
-
-
-#endregion
-
-
-namespace PokemonGo.RocketAPI
-{
-    public class Resources
-    {
-        public const string RpcUrl = @"https://pgorelease.nianticlabs.com/plfe/rpc";
-        public const string NumberedRpcUrl = @"https://pgorelease.nianticlabs.com/plfe/{0}/rpc";
-        public const string PtcLoginUrl = "https://sso.pokemon.com/sso/login?service=https%3A%2F%2Fsso.pokemon.com%2Fsso%2Foauth2.0%2FcallbackAuthorize";
-        public const string PtcLoginOauth = "https://sso.pokemon.com/sso/oauth2.0/accessToken";
-        public const string GoogleGrantRefreshAccessUrl = "https://android.clients.google.com/auth";
-    }
-}
diff --git a/PokemonGo.RocketAPI/app.config b/PokemonGo.RocketAPI/app.config
deleted file mode 100644
index 8460dd4..0000000
--- a/PokemonGo.RocketAPI/app.config
+++ /dev/null
@@ -1,11 +0,0 @@
-<?xml version="1.0" encoding="utf-8"?>
-<configuration>
-  <runtime>
-    <assemblyBinding xmlns="urn:schemas-microsoft-com:asm.v1">
-      <dependentAssembly>
-        <assemblyIdentity name="Newtonsoft.Json" publicKeyToken="30ad4fe6b2a6aeed" culture="neutral" />
-        <bindingRedirect oldVersion="0.0.0.0-9.0.0.0" newVersion="9.0.0.0" />
-      </dependentAssembly>
-    </assemblyBinding>
-  </runtime>
-</configuration>
\ No newline at end of file
diff --git a/PokemonGo.RocketAPI/packages.config b/PokemonGo.RocketAPI/packages.config
deleted file mode 100644
index e4d1dce..0000000
--- a/PokemonGo.RocketAPI/packages.config
+++ /dev/null
@@ -1,12 +0,0 @@
-<?xml version="1.0" encoding="utf-8"?>
-<packages>
-  <package id="C5" version="2.2.5073.27396" targetFramework="net45" />
-  <package id="EnterpriseLibrary.TransientFaultHandling" version="6.0.1304.0" targetFramework="net45" />
-  <package id="EnterpriseLibrary.TransientFaultHandling.Data" version="6.0.1304.1" targetFramework="net45" />
-  <package id="Google.Protobuf" version="3.0.0-beta3" targetFramework="net45" />
-  <package id="Google.Protobuf.Tools" version="3.0.0-beta3" targetFramework="net45" />
-  <package id="Microsoft.AspNet.WebApi.Client" version="5.2.3" targetFramework="net45" />
-  <package id="Newtonsoft.Json" version="9.0.1" targetFramework="net45" />
-  <package id="S2Geometry" version="1.0.1" targetFramework="net45" />
-  <package id="VarintBitConverter" version="1.0.0.0" targetFramework="net45" />
-</packages>
\ No newline at end of file
diff --git a/README.md b/README.md
deleted file mode 100644
index fb89e17..0000000
--- a/README.md
+++ /dev/null
@@ -1,103 +0,0 @@
-<!-- define warning icon -->
-[1.1]: http://i.imgur.com/M4fJ65n.png (ATTENTION)
-[1.2]: http://i.imgur.com/NNcGs1n.png (BTC)
-<!-- title -->
-<h1>Pokemon Go Bot based on FeroxRevs API</h1>
-<br/>
-![alt tag](https://github.com/Spegeli/Pokemon-Go-Rocket-API/blob/master/Screenshot.png)
-<!-- disclaimer -->
-![alt text][1.1] <strong><em> The contents of this repo are a proof of concept and are for educational use only </em></strong> ![alt text][1.1]
-<br/>
-<br/>
-
-<h2>Table of Contents</h2>
-
-- [Chat](#chat)
-- [Features](#features)
-  - [Screenshots](#screenshots)
-- [Getting Started](#getting-started)
-  - [Installation & Configuration](#install-config)
-  - [Changing Location](#changing-location)
-- [License](#license)
-- [Credits](#credits)
-
-<hr/>
-
-<h2><a name="chat">Chat</a></h2>
-
-Chatting about this Repository can be done on our Discord: https://discord.gg/VsVrjgr <br/>
-Please keep your conversations in the designated channels.
-<br/>
-<hr/>
-<br/>
-<h2><a name="features">Features</a></h2>
-
- - [PTC Login / Google]
- - [Humanlike Walking]<br />
-   (Speed in km/h is configurable via UserSettings)
- - [Farm Pokestops]<br />
-   (use always the nearest from the current location) (Optional: keep within specific distance to Start Point) (MaxDistance configurable via UserSettings)
- - [Farm all Pokemon near your]<br />
-   (Optional: PokemonsNotToCatch List. Disabled by default, can be Enabled via UserSettings, configurable Names via File in Config Folder)
- - [Transfer duplicate Pokemon]<br />
-   (ignore favorite/gym marked) (Optional: Enabled by default, can be Disabled via UserSettings. Keep X amount of everyone and order by CP or IV configurable via UserSettings) (Optional: PokemonsNotToTransfer List configurable via File in Config Folder)
- - [Evolve Pokemon]<br />
-   (Optional: Disabled by default, can be Enabled via UserSettings. PokemonsToEvolve List configurable via File in Config Folder)
- - [Throws away unneeded items]<br />
-   (configurable via UserSettings)
- - [Use best Pokeball & Berry]<br />
-   (depending on Pokemon CP)
- - [Creates Excel CSV File on Startup with your current Pokemon]<br />
-   (including Number, Name, CP & Perfection) (can be found in the Export Folder)
- - [Log File System]<br />
-   (all activity will be tracked in a Log File)
- - [Random Task Delays]
- - [Statistic in the Header] ![alt tag](https://github.com/Spegeli/Pokemon-Go-Rocket-API/blob/master/StatisticScreenshot.png)
- - [Very color and useful Logging]<br />
-   (so you every time up2date what currently happened)
- - and many more ;-)
-
-<br/>
-<h2><a name="screenshots">Screenshots</a></h2><br/>
-- coming soon -<br/>
-<hr/>
-
-<h2><a name="getting-started">Getting Started</a></h2>
-Note: You will need some basic Computer Expierience.<br/>
-Need help? <a name="chat">Join the Chat!</a> **The Issue Tracker is not for help!**<br/>
-<br/>
-<h2><a name="install-config">Installation & Configuration</a></h2><br/>
-
-1. Download and Install [Visual Studio 2015](https://go.microsoft.com/fwlink/?LinkId=691979&clcid=0x409)
-2. Download [this Repository](https://github.com/Spegeli/Pokemon-Go-Rocket-API/archive/master.zip)
-3. Open Pokemon Go Rocket API.sln
-4. On the right hand side, double click on "UserSettings.settings"
-5. Enter the DefaultLatitude and DefaultLongitude [can be found here](http://mondeca.com/index.php/en/any-place-en)
-6. Select the AuthType (Google or Ptc for Pokémon Trainer Club)
-7. If selected Ptc , enter the Username and Password of your Account
-8. Right click on "PokemonGo.RocketAPI.Console" and Set it as Startup Project
-9. Press CTRL + F5 and follow the Instructions
-10. Have fun!<br/>
-
-<h2><a name="changing-location">Changing Location of the Bot</a></h2><br/>
-
-1. Get new latitude and longitude
-2. Delete `LastCoords.ini` from folder `PokemonGo.RocketAPI.Console\bin\Debug\Configs`
-3. Change the value of `DefaultLatitude` and `DefaultLongitude` in `UserSettings.settings`
-4. Compile and run (CTRL + F5)<br/>
-
-<hr/>
-<br/>
-<h2><a name="license">License</a></h2><br/>
-This Project is licensed as GNU (GNU GENERAL PUBLIC LICENSE v3)
-<br/>
-You can find all necessary Information [HERE](https://github.com/Spegeli/Pokemon-Go-Bot/blob/master/LICENSE.md)
-<br/>
-<hr/>
-<br/>
-
-<h2><a name="credits">Credits</a></h2><br/>
-Thanks to Feroxs' hard work on the API & Console we are able to manage something like this.<br/>
-Without him, this would not have been available. <3
-<br/>
-Thanks to everyone who voluntaired by contributing to the Pull Requests!
diff --git a/Screenshot.png b/Screenshot.png
deleted file mode 100644
index 6743f01..0000000
Binary files a/Screenshot.png and /dev/null differ
diff --git a/StatisticScreenshot.png b/StatisticScreenshot.png
deleted file mode 100644
index 055ca04..0000000
Binary files a/StatisticScreenshot.png and /dev/null differ
You may download the files in Public Git.