2020-04-19 11:52:42 +00:00
|
|
|
import logging
|
|
|
|
import sys
|
2020-04-18 11:32:14 +00:00
|
|
|
import time
|
2020-05-05 12:55:06 +00:00
|
|
|
from tkinter import messagebox
|
|
|
|
|
2020-04-19 11:52:42 +00:00
|
|
|
import win32con
|
|
|
|
import win32gui
|
2020-04-18 11:32:14 +00:00
|
|
|
from threading import Thread
|
|
|
|
|
2020-04-15 11:27:26 +00:00
|
|
|
import cv2
|
2020-04-18 11:32:14 +00:00
|
|
|
import pywintypes
|
2020-04-19 11:52:42 +00:00
|
|
|
import fishy
|
2020-05-05 12:55:06 +00:00
|
|
|
from fishy.systems.fishing_event import HookEvent, StickEvent, LookEvent, IdleEvent
|
|
|
|
from fishy.systems.fishing_mode import FishingMode
|
|
|
|
from fishy.systems.globals import G
|
|
|
|
from fishy.systems.pixel_loc import PixelLoc
|
|
|
|
from fishy.systems.window import Window
|
|
|
|
from fishy.systems.auto_update import auto_upgrade
|
2020-04-27 21:19:30 +00:00
|
|
|
from fishy.systems import helper, web
|
2020-04-17 13:08:26 +00:00
|
|
|
from fishy.systems.config import Config
|
2020-04-20 19:46:12 +00:00
|
|
|
from fishy.systems.gui import GUI, GUIEvent, GUIFunction
|
2020-05-05 12:55:06 +00:00
|
|
|
from fishy.systems.terms_gui import check_eula
|
2020-04-18 11:32:14 +00:00
|
|
|
|
|
|
|
|
|
|
|
class Fishy:
|
2020-04-27 21:19:30 +00:00
|
|
|
def __init__(self, gui_ref, gui_event_buffer, config):
|
2020-04-18 11:32:14 +00:00
|
|
|
self.gui_events = gui_event_buffer
|
|
|
|
self.start = False
|
|
|
|
self.fishPixWindow = None
|
|
|
|
self.fishy_thread = None
|
|
|
|
self.gui = gui_ref
|
2020-04-27 21:19:30 +00:00
|
|
|
self.config = config
|
2020-04-18 11:32:14 +00:00
|
|
|
|
2020-04-27 21:19:30 +00:00
|
|
|
def start_fishing(self, action_key: str, borderless: bool, collect_r: bool):
|
2020-04-18 11:32:14 +00:00
|
|
|
"""
|
|
|
|
Starts the fishing
|
|
|
|
code explained in comments in detail
|
|
|
|
"""
|
|
|
|
|
|
|
|
# initialize widow
|
|
|
|
try:
|
|
|
|
Window.Init(borderless)
|
|
|
|
except pywintypes.error:
|
|
|
|
logging.info("Game window not found")
|
|
|
|
self.start = False
|
2019-02-16 11:32:20 +00:00
|
|
|
return
|
|
|
|
|
2020-04-18 11:32:14 +00:00
|
|
|
# initializes fishing modes and their callbacks
|
2020-04-19 11:52:42 +00:00
|
|
|
FishingMode("hook", 0, HookEvent(action_key, collect_r))
|
2020-04-18 11:32:14 +00:00
|
|
|
FishingMode("stick", 1, StickEvent())
|
|
|
|
FishingMode("look", 2, LookEvent())
|
2020-04-27 21:19:30 +00:00
|
|
|
FishingMode("idle", 3, IdleEvent(self.config.get("uid")))
|
2019-02-05 15:18:20 +00:00
|
|
|
|
2020-04-18 11:32:14 +00:00
|
|
|
self.fishPixWindow = Window(color=cv2.COLOR_RGB2HSV)
|
2019-02-15 13:44:49 +00:00
|
|
|
|
2020-04-18 11:32:14 +00:00
|
|
|
# check for game window and stuff
|
|
|
|
self.gui.call(GUIFunction.STARTED, (True,))
|
2020-04-23 08:51:28 +00:00
|
|
|
logging.info("Starting the bot engine, look at the fishing hole to start fishing")
|
2020-05-05 12:55:06 +00:00
|
|
|
Thread(target=wait_and_check, args=(self.gui,)).start()
|
2020-04-18 11:32:14 +00:00
|
|
|
while self.start:
|
2019-06-29 20:35:53 +00:00
|
|
|
# Services to be ran in the start of the main loop
|
2019-02-07 22:03:28 +00:00
|
|
|
Window.Loop()
|
|
|
|
|
2019-06-29 20:35:53 +00:00
|
|
|
# get the PixelLoc and find the color values, to give it to `FishingMode.Loop`
|
2020-04-18 11:32:14 +00:00
|
|
|
self.fishPixWindow.crop = PixelLoc.val
|
|
|
|
hueValue = self.fishPixWindow.getCapture()[0][0][0]
|
|
|
|
FishingMode.Loop(hueValue)
|
2019-06-29 20:35:53 +00:00
|
|
|
# Services to be ran in the end of the main loop
|
2019-02-07 22:03:28 +00:00
|
|
|
Window.LoopEnd()
|
2020-04-18 11:32:14 +00:00
|
|
|
logging.info("Fishing engine stopped")
|
|
|
|
self.gui.call(GUIFunction.STARTED, (False,))
|
|
|
|
|
|
|
|
def start_event_handler(self):
|
|
|
|
while True:
|
|
|
|
while len(self.gui_events) > 0:
|
|
|
|
event = self.gui_events.pop(0)
|
|
|
|
|
|
|
|
if event[0] == GUIEvent.START_BUTTON:
|
|
|
|
self.start = not self.start
|
|
|
|
if self.start:
|
|
|
|
self.fishy_thread = Thread(target=self.start_fishing, args=(*event[1],))
|
|
|
|
self.fishy_thread.start()
|
|
|
|
elif event[0] == GUIEvent.CHECK_PIXELVAL:
|
|
|
|
if self.start:
|
|
|
|
self.show_pixel_vals()
|
|
|
|
else:
|
|
|
|
logging.debug("Start the engine first before running this command")
|
|
|
|
elif event[0] == GUIEvent.QUIT:
|
|
|
|
self.start = False
|
|
|
|
return
|
|
|
|
|
|
|
|
def show_pixel_vals(self):
|
|
|
|
def show():
|
|
|
|
freq = 0.5
|
|
|
|
t = 0
|
|
|
|
while t < 10.0:
|
|
|
|
t += freq
|
|
|
|
logging.debug(str(FishingMode.CurrentMode.label) + ":" + str(self.fishPixWindow.getCapture()[0][0]))
|
|
|
|
time.sleep(freq)
|
|
|
|
|
|
|
|
logging.debug("Will display pixel values for 10 seconds")
|
|
|
|
time.sleep(5)
|
|
|
|
Thread(target=show, args=()).start()
|
2018-05-03 16:37:18 +00:00
|
|
|
|
|
|
|
|
2020-04-27 21:19:30 +00:00
|
|
|
def create_shortcut_first(gui, c):
|
|
|
|
if not c.get("shortcut_created", False):
|
2020-04-20 19:46:12 +00:00
|
|
|
helper.create_shortcut(gui)
|
2020-04-27 21:19:30 +00:00
|
|
|
c.set("shortcut_created", True)
|
|
|
|
|
|
|
|
|
|
|
|
def initialize_uid(config: Config):
|
|
|
|
if config.get("uid") is not None:
|
|
|
|
return
|
|
|
|
|
|
|
|
new_uid = helper.create_new_uid()
|
|
|
|
if web.register_user(new_uid):
|
|
|
|
config.set("uid", new_uid)
|
|
|
|
else:
|
|
|
|
logging.error("Couldn't register uid, some features might not work")
|
|
|
|
|
|
|
|
|
|
|
|
def initialize(gui, c: Config):
|
|
|
|
create_shortcut_first(gui, c)
|
|
|
|
initialize_uid(c)
|
2020-04-19 11:52:42 +00:00
|
|
|
|
2020-05-05 12:55:06 +00:00
|
|
|
new_session = web.get_session(c.get('uid'))
|
|
|
|
if new_session is None:
|
|
|
|
logging.error("Couldn't create a session, some features might not work")
|
|
|
|
print(f"created session {new_session}")
|
|
|
|
|
2020-04-19 11:52:42 +00:00
|
|
|
try:
|
|
|
|
auto_upgrade()
|
|
|
|
except Exception:
|
|
|
|
pass
|
|
|
|
|
|
|
|
if not c.get("debug", False):
|
|
|
|
The_program_to_hide = win32gui.GetForegroundWindow()
|
|
|
|
win32gui.ShowWindow(The_program_to_hide, win32con.SW_HIDE)
|
|
|
|
helper.install_thread_excepthook()
|
|
|
|
sys.excepthook = helper.unhandled_exception_logging
|
|
|
|
|
2020-04-27 21:19:30 +00:00
|
|
|
helper.check_addon()
|
|
|
|
|
2020-04-20 19:46:12 +00:00
|
|
|
|
2020-05-05 12:55:06 +00:00
|
|
|
def wait_and_check(gui):
|
2020-04-20 13:03:44 +00:00
|
|
|
time.sleep(10)
|
|
|
|
if not G.FishingStarted:
|
2020-05-05 12:55:06 +00:00
|
|
|
gui.call(GUIFunction.SHOW_ERROR, ("Doesn't look like fishing has started\n\n"
|
|
|
|
"Make sure ProvisionsChalutier addon is visible clearly on top "
|
|
|
|
"left corner of the screen, either,\n"
|
|
|
|
"1) Outdated addons are disabled\n"
|
|
|
|
"2) Other addons are overlapping ProvisionsChalutier\n"
|
|
|
|
"3) Post processing (re shader) is on\n\n"
|
|
|
|
"If fixing those doesnt work, try running the bot as admin",))
|
|
|
|
|
|
|
|
|
|
|
|
def ask_terms():
|
|
|
|
messagebox.askquestion("Terms and Condition", )
|
2020-04-20 13:03:44 +00:00
|
|
|
|
|
|
|
|
2020-04-19 11:52:42 +00:00
|
|
|
def main():
|
|
|
|
c = Config()
|
2020-05-05 12:55:06 +00:00
|
|
|
|
|
|
|
if not check_eula(c):
|
|
|
|
return
|
|
|
|
|
2020-04-19 11:52:42 +00:00
|
|
|
events_buffer = []
|
|
|
|
gui = GUI(c, lambda a, b=None: events_buffer.append((a, b)))
|
2020-04-17 13:08:26 +00:00
|
|
|
gui.start()
|
2020-04-18 04:21:18 +00:00
|
|
|
|
2020-05-05 12:55:06 +00:00
|
|
|
logging.info(f"Fishybot v{fishy.__version__}")
|
2020-04-27 21:19:30 +00:00
|
|
|
initialize(gui, c)
|
2020-04-18 11:32:14 +00:00
|
|
|
|
2020-05-05 12:55:06 +00:00
|
|
|
bot = Fishy(gui, events_buffer, c)
|
2020-04-19 11:52:42 +00:00
|
|
|
bot.start_event_handler()
|
2020-04-15 11:27:26 +00:00
|
|
|
|
|
|
|
|
|
|
|
if __name__ == "__main__":
|
|
|
|
main()
|