Poke API is a port for Ruby from pgoapi and also allows for any automatic parsing of a requests and responses.
- Unofficial, please use at your own RISK.
- Use a throwaway account if possible.
- PTC & Google Authentication supported (use full e-mail address for Google)
- Parses geolocation using Geocoder (parses addresses, postcodes, ip addresses, lat/long, etc)
- Ability to chain requests and receive response in a single call
- Logger available, you can also specify your own log formatter and/or log level
- Protobuf files are modified slightly to the new Proto syntax 3 (Ruby is incompatible with 2)
- A lot of RPC calls, they are listed under
lib/poke-api/POGOProtos/Networking/Requests/RequestType.rb
(requires testing, but appears to be in working order)
You can use bundler and refer directly to this repository
gem 'poke-api',
git: "https://github.com/nabeelamjad/poke-api.git",
tag: '0.0.4'
Or, alternatively you can download the repository and run gem build poke-api.gemspec
followed with gem install poke-api-0.0.3.gem
NOTE - This gem relies on header files for Ruby to install the google-protobuf
gem.
- Windows: You will need the Ruby DevKit applied to your Ruby, please see RubyInstaller
- Linux:
- Debian based:
sudo apt-get install ruby-dev
- RPM based:
sudo yum install ruby-devel
- SuSe based:
sudo zypper install ruby-devel
- Debian based:
Running provided example.rb
with your own credentials
[2016-07-22T00:06:08+00:00]: INFO > Poke::API::Client --: [+] Logging in user: <your_user>
[2016-07-22T00:06:09+00:00]: INFO > Poke::API::Client --: [+] Login Successful
[2016-07-22T00:06:09+00:00]: INFO > Poke::API::RequestBuilder --: [+] Adding 'GET_PLAYER' to RPC request
[2016-07-22T00:06:09+00:00]: INFO > Poke::API::RequestBuilder --: [+] Adding 'GET_HATCHED_EGGS' to RPC request
[2016-07-22T00:06:09+00:00]: INFO > Poke::API::RequestBuilder --: [+] Adding 'GET_INVENTORY' to RPC request
[2016-07-22T00:06:09+00:00]: INFO > Poke::API::RequestBuilder --: [+] Adding 'CHECK_AWARDED_BADGES' to RPC request
[2016-07-22T00:06:09+00:00]: INFO > Poke::API::RequestBuilder --: [+] Adding 'DOWNLOAD_SETTINGS' to RPC request with arguments
[2016-07-22T00:06:09+00:00]: INFO > Poke::API::RequestBuilder --: [+] Executing RPC request
[2016-07-22T00:06:09+00:00]: INFO > Poke::API::Response --: [+] Decoding Main RPC responses
[2016-07-22T00:06:09+00:00]: INFO > Poke::API::Response --: [+] Decoding Sub RPC responses
[2016-07-22T00:06:09+00:00]: INFO > Poke::API::Client --: [+] Cleaning up RPC requests
[2016-07-22T00:06:09+00:00]: INFO > Poke::API::Client --: [+] Given location: New York, NY, USA
[2016-07-22T00:06:09+00:00]: INFO > Poke::API::Client --: [+] Lat/Long: 40.7127837, -74.0059413
[2016-07-22T00:06:09+00:00]: INFO > Poke::API::RequestBuilder --: [+] Adding 'GET_MAP_OBJECTS' to RPC request with arguments
[2016-07-22T00:06:09+00:00]: INFO > Poke::API::RequestBuilder --: [+] Executing RPC request
[2016-07-22T00:06:09+00:00]: INFO > Poke::API::Response --: [+] Decoding Main RPC responses
[2016-07-22T00:06:09+00:00]: INFO > Poke::API::Response --: [+] Decoding Sub RPC responses
[2016-07-22T00:06:09+00:00]: INFO > Poke::API::Client --: [+] Cleaning up RPC requests
{:GET_MAP_OBJECTS=>
{:map_cells=>
[{:s2_cell_id=>9926595610352287744,
:current_timestamp_ms=>1469145969687,
:forts=>
[{:id=>"1a080ce7d62c464da0ab6c7c4f3eb1cb.16",
:last_modified_timestamp_ms=>1469143005205,
:latitude=>40.717921,
:longitude=>-74.015862,
:owned_by_team=>:NEUTRAL,
:guard_pokemon_id=>:MISSINGNO,
:guard_pokemon_cp=>0,
:enabled=>true,
:type=>:CHECKPOINT,
:gym_points=>0,
:is_in_battle=>false,
:active_fort_modifier=>"",
:lure_info=>nil,
:cooldown_complete_timestamp_ms=>0,
:sponsor=>:UNSET_SPONSOR,
:rendering_type=>:DEFAULT}],
:spawn_points=>
[{:latitude=>40.71796568193216, :longitude=>-74.01601166049142},
{:latitude=>40.71791521124943, :longitude=>-74.01674614317368},
{:latitude=>40.718068159209885, :longitude=>-74.01564441809084}],
:wild_pokemons=>[],
:deleted_objects=>[],
:is_truncated_list=>false,
:fort_summaries=>[],
:decimated_spawn_points=>[],
:catchable_pokemons=>[],
:nearby_pokemons=>[]}],
:status=>:SUCCESS}}
An RPC request can be made on its own or with multiple calls, it also provides the ability to specify arguments. You can find all the supported requests under lib/poke-api/POGOProtos/Networking/Requests/RequestType.rb
. Please note that you will need to check if any of these requests require arguments, these can be found under the folder lib/poke-api/POGOProtos/Networking/Requests/Messages
using the same naming convention.
Let's assume we want to delete a few great balls from our inventory
If you open RequestType.rb
we can see that there's an entry for :RECYCLE_INVENTORY_ITEM
. We now know that our call is recycle_inventory_item
, next we have to find out if there're any arguments to this call. We can find any arguments inside the Messages
folder, we see a file named RecycleInventoryItemMessage.rb
which contains two arguments: item_id
and count
. Furthermore we can see that item_id
directly links to POGOProtos.Inventory.Item.ItemId
, this is a file you can open as well with the item ids specified inside. In here we can see the Item ID for a great ball is 2.
Our example request could be as follows:
require 'poke-api'
# Instantiate our client
client = Poke::API::Client.new
# Both PTC/Google available as authentication provider
client.store_location('New York')
client.login('[email protected]', 'password', 'google')
# Add RPC calls
client.recycle_inventory_item(item_id: 2, count: 2)
# You can inspect the client before performing the call
puts client.inspect
=> #<Poke::API::Client @auth=#<Poke::API::Auth::GOOGLE> @reqs=[{:RECYCLE_INVENTORY_ITEM=>{:item_id=>2, :count=>2}}] @lat=4630926632231391130 @lng=13858280158942612615 @alt=0>
# Perform your RPC call
call = client.call
# A <Poke::API::Response> object is returned and decorated with your request and response in a Hash format
# Request
puts call.request.inspect
[
{
:RECYCLE_INVENTORY_ITEM => {
:item_id=>2,
:count=>2
}
}
]
# Response
puts call.response.inspect
{
:RECYCLE_INVENTORY_ITEM = >{
:result=>:SUCCESS,
:new_count=>14
},
:status_code => 1,
:api_url => "",
:error => ""
}
If you wish to change the log level you can do so before instantiating the client by using Poke::API::Logging.log_level = :INFO
where :INFO
is the desired level, possible values are: :DEBUG
, :INFO
, :WARN
, :FATAL
and UNKNOWN
The log formatter format can also be customised, a default one is provided. You can provide a proc
to Poke::API::Logging.formatter
to change it. More information can be found at Class#Logger
Example:
require 'poke-api'
# Use :DEBUG for extra verbosity if required to troubleshoot
Poke::API::Logging.log_level = :DEBUG
Poke::API::Logging.formatter = proc do |severity, datetime, progname, msg|
"My custom logger - #{msg}\n"
end
client = Poke::API::Client.new
client.store_location('London')
#=> My custom logger - [+] Given location: London, UK
#=> My custom logger - [+] Lat/Long: 51.5073509, -0.1277583
Google's S2 Geometry library has not been ported over to Ruby yet, you will need to find a way to obtain cell_ids
to scan for (either through some library or through your own custom function). It is possible to do this to some degree using Geocoder, however it is not as extensive as S2-Geometry. More information can be found in this article. I welcome any pull request/suggestion on how to tackle this so I can add a Poke::API::Helper
method to generate cell_ids
A workaround can be found on this comment on how to obtain cell_ids for a given location and optionally enter a radius (defaults to 10 to your given location).
Any contributions are most welcome, I don't have much time to spend on this project so I appreciate everything.
tejado - Pretty much everything as this repository is a direct 'conversion' to the best of my ability
AeonLucid - Protobufs
xssc - GPSOauth (Google Login)