From 3bf5fb27b38b7225d6fb539a4f1f5004a8072c9e Mon Sep 17 00:00:00 2001 From: Floris van Liere Date: Sun, 31 Jul 2016 22:15:29 +0200 Subject: [PATCH 1/2] Add recycle option to keep a combined number of balls (#2070) --- configs/config.json.example | 2 +- data/items.json | 1 + pokemongo_bot/cell_workers/recycle_items.py | 61 ++++++++++++++++----- 3 files changed, 50 insertions(+), 14 deletions(-) diff --git a/configs/config.json.example b/configs/config.json.example index 7c250203d5..fc25cd6d2e 100644 --- a/configs/config.json.example +++ b/configs/config.json.example @@ -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 }, diff --git a/data/items.json b/data/items.json index 6a7668f5ed..ec44c10800 100644 --- a/data/items.json +++ b/data/items.json @@ -5,6 +5,7 @@ "2": "Greatball", "3": "Ultraball", "4": "Masterball", + "5": "Anyball", "101": "Potion", "102": "Super Potion", diff --git a/pokemongo_bot/cell_workers/recycle_items.py b/pokemongo_bot/cell_workers/recycle_items.py index 6492cb24e8..6905ce8dd9 100644 --- a/pokemongo_bot/cell_workers/recycle_items.py +++ b/pokemongo_bot/cell_workers/recycle_items.py @@ -7,7 +7,21 @@ 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) @@ -15,19 +29,23 @@ def work(self): 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) @@ -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) From 8af5ec294652f8f71939d6541dc008a7a5b041b1 Mon Sep 17 00:00:00 2001 From: Floris van Liere Date: Sun, 31 Jul 2016 22:26:41 +0200 Subject: [PATCH 2/2] Fix bug where number_recycle_items is not set. --- pokemongo_bot/cell_workers/recycle_items.py | 15 ++++++++------- 1 file changed, 8 insertions(+), 7 deletions(-) diff --git a/pokemongo_bot/cell_workers/recycle_items.py b/pokemongo_bot/cell_workers/recycle_items.py index 6905ce8dd9..760ac45821 100644 --- a/pokemongo_bot/cell_workers/recycle_items.py +++ b/pokemongo_bot/cell_workers/recycle_items.py @@ -21,15 +21,16 @@ 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) + id_filter_keep = None + 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) - 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 + return id_filter_keep def recycle(self, item_id, recycle_count, show_amount=True): item_name = self.get_item_name(item_id)