Skip to content

Commit

Permalink
Add recycle option to keep a combined number of balls (PokemonGoF#2070)
Browse files Browse the repository at this point in the history
  • Loading branch information
Breakster committed Jul 31, 2016
1 parent 17cf7a9 commit 3bf5fb2
Show file tree
Hide file tree
Showing 3 changed files with 50 additions and 14 deletions.
2 changes: 1 addition & 1 deletion configs/config.json.example
Original file line number Diff line number Diff line change
Expand Up @@ -62,7 +62,7 @@
"distance_unit": "km",
"reconnecting_timeout": 15,
"item_filter": {
"Pokeball": { "keep" : 100 },
"Anyball": { "keep" : 150 },
"Potion": { "keep" : 10 },
"Super Potion": { "keep" : 20 },
"Hyper Potion": { "keep" : 30 },
Expand Down
1 change: 1 addition & 0 deletions data/items.json
Original file line number Diff line number Diff line change
Expand Up @@ -5,6 +5,7 @@
"2": "Greatball",
"3": "Ultraball",
"4": "Masterball",
"5": "Anyball",

"101": "Potion",
"102": "Super Potion",
Expand Down
61 changes: 48 additions & 13 deletions pokemongo_bot/cell_workers/recycle_items.py
Original file line number Diff line number Diff line change
Expand Up @@ -7,27 +7,45 @@ def work(self):
item_count_dict = self.bot.item_inventory_count('all')

for item_id, bag_count in item_count_dict.iteritems():
item_name = self.bot.item_list[str(item_id)]
item_name = self.get_item_name(item_id)
amount_to_keep = self.get_amount_to_keep(item_id)
bag_count = self.bot.item_inventory_count(item_id)

if (item_name in self.bot.config.item_filter or str(item_id) in self.bot.config.item_filter) and bag_count > amount_to_keep:
items_recycle_count = bag_count - amount_to_keep
self.recycle(item_id, items_recycle_count)

self.recycle_pokeballs()

def get_item_name(self, item_id):
return self.bot.item_list[str(item_id)]

def get_amount_to_keep(self, item_id):
item_name = self.get_item_name(item_id)
id_filter = self.bot.config.item_filter.get(item_name, 0)
if id_filter is not 0:
id_filter_keep = id_filter.get('keep', 20)
else:
id_filter = self.bot.config.item_filter.get(str(item_id), 0)
if id_filter is not 0:
id_filter_keep = id_filter.get('keep', 20)
return id_filter_keep

bag_count = self.bot.item_inventory_count(item_id)
if (item_name in self.bot.config.item_filter or str(item_id) in self.bot.config.item_filter) and bag_count > id_filter_keep:
items_recycle_count = bag_count - id_filter_keep
response_dict_recycle = self.send_recycle_item_request(item_id=item_id, count=items_recycle_count)
result = response_dict_recycle.get('responses', {}).get('RECYCLE_INVENTORY_ITEM', {}).get('result', 0)

if result == 1: # Request success
message_template = "-- Discarded {}x {} (keeps only {} maximum) "
message = message_template.format(str(items_recycle_count), item_name, str(id_filter_keep))
logger.log(message, 'green')
else:
logger.log("-- Failed to discard " + item_name, 'red')
def recycle(self, item_id, recycle_count, show_amount=True):
item_name = self.get_item_name(item_id)
response_dict_recycle = self.send_recycle_item_request(item_id=item_id, count=recycle_count)
result = response_dict_recycle.get('responses', {}).get('RECYCLE_INVENTORY_ITEM', {}).get('result', 0)

if result == 1: # Request success
message = "-- Discarded {}x {} "
message = message.format(str(recycle_count),
item_name)
if show_amount:
message += "(keeps only {} maximum) "
message = message.format(str(self.get_amount_to_keep(item_id)))
logger.log(message, 'green')
else:
logger.log("-- Failed to discard " + item_name, 'red')

def send_recycle_item_request(self, item_id, count):
self.bot.api.recycle_inventory_item(item_id=item_id, count=count)
Expand All @@ -36,3 +54,20 @@ def send_recycle_item_request(self, item_id, count):
# Example of good request response
#{'responses': {'RECYCLE_INVENTORY_ITEM': {'result': 1, 'new_count': 46}}, 'status_code': 1, 'auth_ticket': {'expire_timestamp_ms': 1469306228058L, 'start': '/HycFyfrT4t2yB2Ij+yoi+on778aymMgxY6RQgvrGAfQlNzRuIjpcnDd5dAxmfoTqDQrbz1m2dGqAIhJ+eFapg==', 'end': 'f5NOZ95a843tgzprJo4W7Q=='}, 'request_id': 8145806132888207460L}
return inventory_req

def recycle_pokeballs(self):
number_of_balls_to_keep_logged = False
number_of_balls_to_keep = self.get_amount_to_keep(5)
total_amount_of_balls = 0

for ball_id in [4, 3, 2, 1]:
bag_count = self.bot.item_inventory_count(ball_id)
if bag_count:
total_amount_of_balls += bag_count
if total_amount_of_balls > number_of_balls_to_keep:
if not number_of_balls_to_keep_logged:
logger.log('Keeping {} balls in total'.format(str(number_of_balls_to_keep)), 'green')
number_of_balls_to_keep_logged = True
recycle_amount = total_amount_of_balls - number_of_balls_to_keep
number_of_balls_to_keep -= recycle_amount
self.recycle(ball_id, recycle_amount, show_amount=False)

0 comments on commit 3bf5fb2

Please sign in to comment.