/PGPool

POGO Account Manager

Primary LanguagePython

PGPool

A simple webservice for account management.

  • Keeps a list of unused / in use accounts and which tools/instances they are being used in.
  • Stores all relevant account information like level, XP, team, coins, dust, last location, captcha / ban / shadowban status and many more.
  • Allows updates to these account information via REST API.
  • Logs certain events like when the account gets assigned to a system, when warning / ban flags occur the first time and when they disappear.
  • Instantly usable with every software that utilizes the MrMime pgoapi wrapper library

PGPool does NOT use any 3rd party API to actually log in to the accounts. It is purely a management software and therefore safe to use.

PGPool was designed to allow continuous execution of other tools that need to swap accounts every now and then. A typical scenario is a tool that requests a certain number of accounts to operate with, posting account detail updates to PGPool on a regular basis and if they fail release them to the pool and pick a new one. So instead of having a CSV file as account pool you're having a database with tons of more details and account history.

Support the Author Donate

If you like this tool and feel the urgent need to thank me, the best way to do it is via BitCoin (1PNdXhzvvz2ytCf8mbFdF9MQaABzpjSbJi) or PayPal. Seriously, that would be so awesome! :-D If you can't or don't want to use PayPal or BitCoin some level 30+ accounts. You can find me on the PGTools Discord Server and on various other Pokémon GO related Discords as "sLoPPydrive".

Get Help

Come join the official PGTools Discord Server for PGScout, PGNumbra, PGPool and the PGTools RocketMap and PokeAlarm forks to get help or just hang around. You are very welcome. :)

Quick Start

Again, be aware that PGPool currently only makes sense if you use any product using the MrMime pgoapi wrapper library (e.g. PGScout, PGNumbra, my RocketMap branch MIX_SCYTHER).

The only thing you need is a MySQL database set up and the usual pip install -r requirements.txt.

Setting up PGPool

  1. Copy config.json.sample to config.json.
  2. Adjust settings for listening host:port and your database in config.json.
  3. Run PGPool with python pgpool.py.

Some words about the non-obvious options in config.json:

  • account_release_timeout defines the time in minutes after which accounts that are still assigned (e.g. have not been released properly) to a system but have not been updated in this time will be released to the pool again. Default value is 120 minutes (2 hours). You can set it to 0 to fully disable auto-releasing.

Importing Accounts

The preferred way to load new accounts into PGPool is to put them in a CSV file and let PGNumbra run with --accounts-file and --pgpool-url. This checks and adds them to PGPool in one run. If you chose a location near a Pokestop they will also be at least level 2 after that.

Alternatively: With PGPool comes a tool called pgpool-import.py which takes a CSV file and creates new account records in the database. These accounts don't have any account details yet (most important ban/shadowban status), so they won't get picked if a client requests any accounts. For them to become active you need to check them first, e.g. by running PGNumbra Tools on them. Commandline options of pgpool-import.py are:

  -i IMPORT_CSV, --import-csv IMPORT_CSV
             Filename of a CSV file to import accounts from.
  -l LEVEL, --level LEVEL
             Trainer level of imported accounts.

The format of the CSV file should be one (and only one, don't mix them up!) of:

  • auth,username,password where auth is either ptc or google
  • username,password where auth will be assumed as ptc

API

Let's assume PGPool runs at the default URL http://localhost:4242. Then the following requests are possible:

Requesting Accounts

URL: http://localhost:4242/account/request Method: GET

Parameter Required Default Description
system_id yes none Tells PGPool which system is requesting the accounts. Cannot be empty.
count no 1 The number of accounts to request
min_level no 1 Minimum number of trainer level being requested. If you want reliable IV encounter data your accounts should be at least level 30
max_level no 40 Maximum number of trainer level. Maybe you want to reserve level 30 accounts for other tools.
reuse no false If set to yes the client will also receive good accounts that were previously assigned to the given system_id. Useful on client startup to reuse accounts.
banned_or_new no false If set to true only banned/shadowbanned and new accounts with unknown status will be returned.

Returns a JSON object or a list of JSON objects representing accounts. These records do not contain every account detail because the client usually logs in to the accounts and get these details directly from the POGO servers:

{
    "auth_service": "ptc",
    "username": "myuser",
    "password": "mypass",
    "latitude": 51.93978239,
    "longitude": 6.98748234,
    "rareless_scans": 10,
    "shadowbanned": true,
    "last_modified": 1503574917
}

Updating Accounts

URL: http://localhost:4242/account/update Method: POST

Request data is either a single JSON object or a list of JSON objects that contain one or more attributes to set on the account.

Attribute Description
auth_service Either ptc or google
username Self-explanatory
password Self-explanatory
email Email address being specified on account creation
last_modified Date and time of last update
system_id Identifier of system the account is assigned to
latitude Last location a request was performed
longitude Last location a request was performed
level Trainer-level
xp Experience points
encounters Number of Pokemon encounters (not catches!)
balls_thrown Number of balls thrown at Pokemon
captures Number of Pokemon captures
spins Number of Pokestop spins
walked Number of km walked
team One of UNSET, TEAM_YELLOW, TEAM_BLUE ir TEAM_RED
coins Amount of Pokecoins
stardust Amount of Stardust
warn true or false whether the account has a 3rd party app warning or not
banned true or false
ban_flag true or false
tutorial_state currently unused
captcha true or false
rareless_scans Number of consecutive location scans with no rare Pokemon sightings
shadowbanned true or false - client decision!
balls Number of Pokeballs (or other balls) in inventory
total_items Number of total items in inventory
pokemon Number of Pokemon in bag
eggs Number of eggs
incubators Number of incubators

Releasing Accounts

URL: http://localhost:4242/account/release Method: POST

Same as updating accounts (they get updated when they are being released) but the system_id is also set to NULL.

Setting up 3rd Party Apps

General MrMime Support

In your application that utilizes the MrMime pgoapi wrapper library and that should be linked to PGPool to update account details create or edit mrmime_config.json and set at least the following options:

{
    "pgpool_url": "http://localhost:4242",
    "pgpool_system_id": "name_of_system"
}

Note that this only enables the updating of account details. If your application needs to request and release accounts from and to the pool you will need a modified version of your application (read below for RocketMap integration). Maybe a fully automatic mode will be integrated into MrMime some day.

Other options are possible, their default values are:

{
    "pgpool_auto_update": true,         
    "pgpool_update_interval": 60
}
  • pgpool_url: The URL where PGPool is reachable. Must not end with "/".
  • pgpool_system_id: If the app requests or updates accounts they get marked as being in use by this system_id.
  • pgpool_auto_update: Whether MrMime updates PGPool account details automatically.
  • pgpool_update_interval: Update account details in PGPool after next API call if this many seconds have passed.

RocketMap

PGPool is fully integrated into my own RocketMap fork (branch MIX_SCYTHER). To use it, download my fork and set the following config parameters:

  --pgpool-url <url>
  --workers <number of regular workers lvl 1-29>
  --highlvl-workers <optional number of lvl 30+ accounts for encounters>

Now specifying accounts or CSV files will be ignored. Only the number of --workers has to be set (--highlvl-workers is optional). RocketMap also automatically sets the system_id for PGPool to the RocketMap status_name, so you don't have to worry about that either.

PGScout

PGPool is fully integrated into PGScout. To use it, set the following config parameters (on command line or config.ini):

  --pgpool-url <url>
  --pgpool-system-id <system-id>
  --pgpool-num-accounts <num>

Besides configuring the URL and system ID you need to set the number of accounts PGScout should request from PGPool. PGScout by default automatically requests accounts with minimum level 30.

PGNumbra

PGNumbra uses MrMime, so it works with PGPool out of the box. The difference is that PGNumbras shadowcheck.py tool sets an automatic system_id which is pgnumbra_ followed by its process ID. Checked accounts are instantly released after being checked.