Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

A Hat in Time: Implement New Game #2640

Merged
merged 176 commits into from
May 20, 2024
Merged
Show file tree
Hide file tree
Changes from 99 commits
Commits
Show all changes
176 commits
Select commit Hold shift + click to select a range
45ccb99
duh
CookieCat45 Aug 27, 2023
173896b
Fuck it
CookieCat45 Aug 28, 2023
cbdf4d9
Major fixes
CookieCat45 Aug 28, 2023
5c49cca
a
CookieCat45 Aug 28, 2023
6442c40
b
CookieCat45 Aug 28, 2023
906c412
Even more fixes
CookieCat45 Aug 29, 2023
1fd2a21
New option - NoFreeRoamFinale
CookieCat45 Aug 29, 2023
b5475ac
a
CookieCat45 Aug 29, 2023
6d9bfbc
Hat Logic Fix
CookieCat45 Aug 29, 2023
149a42b
Just to be safe
CookieCat45 Aug 29, 2023
2b44619
multiworld.random to world.random
CookieCat45 Aug 29, 2023
0dc211f
KeyError fix
CookieCat45 Aug 30, 2023
c0adc90
Update .gitignore
CookieCat45 Aug 30, 2023
e338826
Update __init__.py
CookieCat45 Aug 30, 2023
a7190b6
Zoinks Scoob
CookieCat45 Aug 30, 2023
a3fd865
ffs
CookieCat45 Aug 30, 2023
949f152
Ruh Roh Raggy, more r-r-r-random bugs!
CookieCat45 Aug 30, 2023
d673b87
0.9b - cleanup + expanded logic difficulty
CookieCat45 Sep 1, 2023
77ac8a7
Update Rules.py
CookieCat45 Sep 1, 2023
2ef4422
Update Regions.py
CookieCat45 Sep 1, 2023
127ce1d
Merge branch 'ArchipelagoMW:main' into main
CookieCat45 Sep 2, 2023
1f916e8
AttributeError fix
CookieCat45 Sep 2, 2023
215594d
0.10b - New Options
CookieCat45 Sep 2, 2023
1daafff
1.0 Preparations
CookieCat45 Sep 8, 2023
02087ed
Docs
CookieCat45 Sep 8, 2023
32561dd
Docs 2
CookieCat45 Sep 8, 2023
6c56f79
Fixes
CookieCat45 Sep 9, 2023
da20a77
Update __init__.py
CookieCat45 Sep 9, 2023
c5b8113
Fixes
CookieCat45 Sep 9, 2023
6cedbe8
variable capture my beloathed
CookieCat45 Sep 9, 2023
0d07ae0
Fixes
CookieCat45 Sep 11, 2023
e3e1c0d
a
CookieCat45 Sep 11, 2023
a1395ee
10 Seconds logic fix
CookieCat45 Sep 12, 2023
714241b
1.1
CookieCat45 Sep 15, 2023
1afb569
1.2
CookieCat45 Oct 4, 2023
13acb67
a
CookieCat45 Oct 13, 2023
0e273dd
New client
CookieCat45 Oct 17, 2023
8b98cd7
More client changes
CookieCat45 Oct 17, 2023
d043c0d
1.3
CookieCat45 Oct 19, 2023
8d3aa7e
Final touch-ups for 1.3
CookieCat45 Oct 19, 2023
6eaf941
1.3.1
CookieCat45 Oct 21, 2023
afdcde8
1.3.3
CookieCat45 Oct 23, 2023
1cf5218
Merge branch 'ArchipelagoMW:main' into main
CookieCat45 Oct 24, 2023
a3e928d
Zero Jumps gen error fix
CookieCat45 Oct 24, 2023
100a5f9
Merge branch 'main' of https://github.com/CookieCat45/Archipelago-ahit
CookieCat45 Oct 24, 2023
a20a9e8
more fixes
CookieCat45 Oct 24, 2023
b4fb763
Formatting improvements
CookieCat45 Oct 25, 2023
6ae347c
Merge branch 'ArchipelagoMW:main' into main
CookieCat45 Oct 27, 2023
8eb351e
typo
CookieCat45 Oct 27, 2023
e178a7c
Update __init__.py
CookieCat45 Oct 27, 2023
f37a718
Revert "Update __init__.py"
CookieCat45 Oct 27, 2023
25a39a4
init
CookieCat45 Oct 27, 2023
2ce7b52
Update to new options API
CookieCat45 Oct 27, 2023
eb6f373
Missed some
CookieCat45 Oct 27, 2023
a028b9a
Snatcher Coins fix
CookieCat45 Oct 27, 2023
eb2bd1c
Missed some more
CookieCat45 Oct 27, 2023
3eaa808
Merge branch 'ArchipelagoMW:main' into new-options-api
CookieCat45 Oct 27, 2023
8c02a96
Merge branch 'ArchipelagoMW:main' into main
CookieCat45 Oct 27, 2023
311966c
some slight touch ups
CookieCat45 Oct 28, 2023
0ede996
Merge branch 'ArchipelagoMW:main' into main
CookieCat45 Oct 30, 2023
b5167bf
Merge branch 'ArchipelagoMW:main' into new-options-api
CookieCat45 Oct 30, 2023
674cf7a
Merge branch 'ArchipelagoMW:main' into main
CookieCat45 Nov 4, 2023
aa71433
Merge branch 'ArchipelagoMW:main' into new-options-api
CookieCat45 Nov 4, 2023
a262b13
rewind
CookieCat45 Nov 4, 2023
60df274
Merge branch 'main' of https://github.com/CookieCat45/Archipelago-ahit
CookieCat45 Nov 4, 2023
bd8698e
a
CookieCat45 Nov 4, 2023
b8948bc
fix things
CookieCat45 Nov 5, 2023
a2360fe
Merge branch 'main' of https://github.com/CookieCat45/Archipelago-ahit
CookieCat45 Nov 5, 2023
58fcd50
Revert "Merge branch 'main' of https://github.com/CookieCat45/Archipe…
CookieCat45 Nov 5, 2023
f4f405f
Update .gitignore
CookieCat45 Nov 5, 2023
db54bed
Merge branch 'ArchipelagoMW:main' into main
CookieCat45 Nov 5, 2023
eea1dd6
Merge branch 'ArchipelagoMW:main' into new-options-api
CookieCat45 Nov 5, 2023
74715c3
1.3.6
CookieCat45 Nov 5, 2023
10e1ed0
Merge branch 'main' of https://github.com/CookieCat45/Archipelago-ahit
CookieCat45 Nov 5, 2023
f451f2c
Merge branch 'ArchipelagoMW:main' into main
CookieCat45 Dec 7, 2023
24b8be7
Merge branch 'ArchipelagoMW:main' into new-options-api
CookieCat45 Dec 8, 2023
0d703b8
Merge branch 'main' into new-options-api
CookieCat45 Dec 8, 2023
98c29b7
Final touch-ups
CookieCat45 Dec 8, 2023
e64fe75
Merge pull request #1 from CookieCat45/new-options-api
CookieCat45 Dec 8, 2023
4f80e15
Merge branch 'ArchipelagoMW:main' into main
CookieCat45 Dec 17, 2023
b9fce5a
Fix client and leftover old options api
CookieCat45 Dec 19, 2023
0ef6c33
Merge branch 'ArchipelagoMW:main' into main
CookieCat45 Dec 19, 2023
6d629a0
Delete setup-ahitclient.py
CookieCat45 Dec 19, 2023
4e12f4c
Merge branch 'main' of https://github.com/CookieCat45/Archipelago-ahit
CookieCat45 Dec 19, 2023
083f5b7
Update .gitignore
CookieCat45 Dec 19, 2023
ae58cd9
Merge branch 'ArchipelagoMW:main' into main
CookieCat45 Dec 28, 2023
185f5b5
Merge branch 'ArchipelagoMW:main' into main
CookieCat45 Jan 3, 2024
f967588
old python version fix
CookieCat45 Jan 4, 2024
4c6974f
proper warnings for invalid act plandos
CookieCat45 Jan 5, 2024
1548da9
Update worlds/ahit/docs/en_A Hat in Time.md
CookieCat45 Jan 16, 2024
2dd3a45
Update worlds/ahit/docs/setup_en.md
CookieCat45 Jan 16, 2024
a431e19
120 char per line
CookieCat45 Jan 16, 2024
0e590b0
"settings" to "options"
CookieCat45 Jan 16, 2024
237fd74
Merge branch 'ArchipelagoMW:main' into main
CookieCat45 Jan 16, 2024
59f45a2
Update DeathWishRules.py
CookieCat45 Jan 17, 2024
806ca07
Merge branch 'main' of https://github.com/CookieCat45/Archipelago-ahit
CookieCat45 Jan 17, 2024
5b8c139
Merge branch 'ArchipelagoMW:main' into main
CookieCat45 Jan 17, 2024
b38d1cd
Update worlds/ahit/docs/en_A Hat in Time.md
CookieCat45 Feb 13, 2024
e713d71
Merge branch 'main' into main
CookieCat45 Feb 13, 2024
9bec739
No more loading the data package
CookieCat45 Feb 19, 2024
5ef32e3
Merge branch 'main' of https://github.com/CookieCat45/Archipelago-ahit
CookieCat45 Feb 19, 2024
64dfb29
cleanup + act plando fixes
CookieCat45 Mar 20, 2024
4f6bf80
almost forgot
CookieCat45 Mar 21, 2024
de02f92
Update Rules.py
CookieCat45 Mar 21, 2024
877d317
Merge branch 'ArchipelagoMW:main' into main
CookieCat45 Mar 21, 2024
0db3dcb
a
CookieCat45 Mar 23, 2024
9f4e34c
Update worlds/ahit/Options.py
CookieCat45 Mar 25, 2024
d47d6c2
Options stuff
CookieCat45 Mar 25, 2024
bcb4195
Merge remote-tracking branch 'origin/main'
CookieCat45 Mar 25, 2024
bf87029
oop
CookieCat45 Mar 25, 2024
dbd2d8f
no unnecessary type hints
CookieCat45 Mar 25, 2024
8480d51
warn about depot download length in setup guide
CookieCat45 Mar 25, 2024
54557e7
Update worlds/ahit/Options.py
CookieCat45 Mar 25, 2024
5700b74
typo
CookieCat45 Mar 25, 2024
b00eb53
Update worlds/ahit/Rules.py
CookieCat45 Mar 25, 2024
2e14859
review stuff
CookieCat45 Mar 25, 2024
67e8f62
Merge remote-tracking branch 'origin/main'
CookieCat45 Mar 25, 2024
e53e75d
More stuff from review
CookieCat45 Mar 26, 2024
0b41527
comment
CookieCat45 Mar 26, 2024
44cf751
Merge branch 'ArchipelagoMW:main' into main
CookieCat45 May 4, 2024
6318a1a
1.5 Update
CookieCat45 May 8, 2024
d572f22
link fix?
CookieCat45 May 8, 2024
634ee6a
link fix 2
CookieCat45 May 8, 2024
edead9a
Update setup_en.md
CookieCat45 May 8, 2024
6416a37
Update setup_en.md
CookieCat45 May 8, 2024
5580f70
Update setup_en.md
CookieCat45 May 8, 2024
ff9f33e
Evil
CookieCat45 May 10, 2024
455b60f
Good fucking lord
CookieCat45 May 10, 2024
3675e01
Review stuff again + Logic fixes
CookieCat45 May 12, 2024
380f576
More review stuff
CookieCat45 May 12, 2024
2a7564d
Even more review stuff - we're almost done
CookieCat45 May 12, 2024
b429021
DW review stuff
CookieCat45 May 12, 2024
f47b026
Finish up review stuff
CookieCat45 May 12, 2024
bc7e108
remove leftover stuff
CookieCat45 May 12, 2024
989dcab
a
CookieCat45 May 12, 2024
3799f49
assert item
CookieCat45 May 12, 2024
092cb11
add A Hat in Time to readme/codeowners files
CookieCat45 May 13, 2024
88a54a2
Merge branch 'main' into main
CookieCat45 May 13, 2024
8e8206e
Fix range options not being corrected properly
CookieCat45 May 13, 2024
f66c37d
120 chars per line in docs
CookieCat45 May 13, 2024
4257552
Update worlds/ahit/Regions.py
CookieCat45 May 13, 2024
2e56a04
Update worlds/ahit/DeathWishLocations.py
CookieCat45 May 13, 2024
1e6bec6
Remove some unnecessary option.class.value
CookieCat45 May 13, 2024
8e80b9c
Remove data_version and more option.class.value
CookieCat45 May 13, 2024
ecf6917
Update worlds/ahit/Items.py
CookieCat45 May 13, 2024
c20076f
Remove the rest of option.class.value
CookieCat45 May 13, 2024
61257b1
Update worlds/ahit/DeathWishLocations.py
CookieCat45 May 13, 2024
9a0964f
review stuff
CookieCat45 May 13, 2024
1450d33
Replace connect_regions with Region.connect
CookieCat45 May 13, 2024
e33c5cc
review stuff
CookieCat45 May 13, 2024
e7c2bea
Remove unnecessary Optional from LocData
CookieCat45 May 13, 2024
ba0c184
Remove HatType.NONE
CookieCat45 May 13, 2024
1244477
Update worlds/ahit/test/TestActs.py
CookieCat45 May 13, 2024
1f148cb
fix so default tests actually don't run
CookieCat45 May 13, 2024
f61ab04
Improve performance for death wish rules
CookieCat45 May 13, 2024
0e54140
rename test file
CookieCat45 May 13, 2024
850dfba
change test imports
CookieCat45 May 13, 2024
e061adf
1000 is probably unnecessary
CookieCat45 May 13, 2024
b45ab0f
Merge branch 'main' into main
CookieCat45 May 13, 2024
6331ab2
a
CookieCat45 May 13, 2024
64f742f
change state.count to state.has
CookieCat45 May 14, 2024
39b102e
stuff
CookieCat45 May 15, 2024
4027d2f
starting inventory hats fix
CookieCat45 May 15, 2024
1768246
shouldn't have done this lol
CookieCat45 May 15, 2024
530b65c
make ship shape task goal equal to number of tasksanity checks if set…
CookieCat45 May 16, 2024
6951766
a
CookieCat45 May 16, 2024
dead6eb
change act shuffle starting acts + logic updates
CookieCat45 May 17, 2024
0fcb1a6
dumb
CookieCat45 May 17, 2024
b299d96
Merge branch 'main' into main
CookieCat45 May 18, 2024
3b75bb0
option groups + lambda capture cringe + typo
CookieCat45 May 18, 2024
f4c7531
a
CookieCat45 May 18, 2024
a543a3a
b
CookieCat45 May 18, 2024
6f6bf41
missing option in groups
CookieCat45 May 18, 2024
85b9794
Merge branch 'ArchipelagoMW:main' into main
CookieCat45 May 19, 2024
2c7ff4b
c
CookieCat45 May 19, 2024
acdc41e
Merge branch 'main' into main
Berserker66 May 20, 2024
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
8 changes: 8 additions & 0 deletions AHITClient.py
Original file line number Diff line number Diff line change
@@ -0,0 +1,8 @@
from worlds.ahit.Client import launch
import Utils
import ModuleUpdate
ModuleUpdate.update()

if __name__ == "__main__":
Utils.init_logging("AHITClient", exception_logger="Client")
launch()
Binary file added data/yatta.ico
Binary file not shown.
Binary file added data/yatta.png
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
235 changes: 235 additions & 0 deletions worlds/ahit/Client.py
Original file line number Diff line number Diff line change
@@ -0,0 +1,235 @@
import asyncio
import Utils
import websockets
import functools
from copy import deepcopy
from typing import List, Any, Iterable
from NetUtils import decode, encode, JSONtoTextParser, JSONMessagePart, NetworkItem
from MultiServer import Endpoint
from CommonClient import CommonContext, gui_enabled, ClientCommandProcessor, logger, get_base_parser

DEBUG = False


class AHITJSONToTextParser(JSONtoTextParser):
def _handle_color(self, node: JSONMessagePart):
return self._handle_text(node) # No colors for the in-game text


class AHITCommandProcessor(ClientCommandProcessor):
def __init__(self, ctx: CommonContext):
super().__init__(ctx)
CookieCat45 marked this conversation as resolved.
Show resolved Hide resolved

def _cmd_ahit(self):
"""Check AHIT Connection State"""
if isinstance(self.ctx, AHITContext):
logger.info(f"AHIT Status: {self.ctx.get_ahit_status()}")


class AHITContext(CommonContext):
command_processor = AHITCommandProcessor
game = "A Hat in Time"

def __init__(self, server_address, password):
super().__init__(server_address, password)
self.proxy = None
self.proxy_task = None
self.gamejsontotext = AHITJSONToTextParser(self)
self.autoreconnect_task = None
self.endpoint = None
self.items_handling = 0b111
self.room_info = None
self.connected_msg = None
self.game_connected = False
self.awaiting_info = False
self.full_inventory: List[Any] = []
self.server_msgs: List[Any] = []

async def server_auth(self, password_requested: bool = False):
if password_requested and not self.password:
await super(AHITContext, self).server_auth(password_requested)

await self.get_username()
await self.send_connect()

def get_ahit_status(self) -> str:
if not self.is_proxy_connected():
return "Not connected to A Hat in Time"

return "Connected to A Hat in Time"

async def send_msgs_proxy(self, msgs: Iterable[dict]) -> bool:
""" `msgs` JSON serializable """
if not self.endpoint or not self.endpoint.socket.open or self.endpoint.socket.closed:
return False

if DEBUG:
logger.info(f"Outgoing message: {msgs}")

await self.endpoint.socket.send(msgs)
return True

async def disconnect(self, allow_autoreconnect: bool = False):
await super().disconnect(allow_autoreconnect)

async def disconnect_proxy(self):
if self.endpoint and not self.endpoint.socket.closed:
await self.endpoint.socket.close()
if self.proxy_task is not None:
await self.proxy_task

def is_connected(self) -> bool:
return self.server and self.server.socket.open

def is_proxy_connected(self) -> bool:
return self.endpoint and self.endpoint.socket.open

def on_print_json(self, args: dict):
text = self.gamejsontotext(deepcopy(args["data"]))
msg = {"cmd": "PrintJSON", "data": [{"text": text}], "type": "Chat"}
self.server_msgs.append(encode([msg]))

if self.ui:
self.ui.print_json(args["data"])
else:
text = self.jsontotextparser(args["data"])
logger.info(text)

def update_items(self):
# just to be safe - we might still have an inventory from a different room
if not self.is_connected():
return

self.server_msgs.append(encode([{"cmd": "ReceivedItems", "index": 0, "items": self.full_inventory}]))

def on_package(self, cmd: str, args: dict):
if cmd == "Connected":
self.connected_msg = encode([args])
if self.awaiting_info:
self.server_msgs.append(self.room_info)
self.update_items()
self.awaiting_info = False

elif cmd == "ReceivedItems":
if args["index"] == 0:
self.full_inventory.clear()

for item in args["items"]:
self.full_inventory.append(NetworkItem(*item))

self.server_msgs.append(encode([args]))

elif cmd == "RoomInfo":
self.seed_name = args["seed_name"]
self.room_info = encode([args])

else:
if cmd != "PrintJSON":
self.server_msgs.append(encode([args]))

def run_gui(self):
from kvui import GameManager

class AHITManager(GameManager):
logging_pairs = [
("Client", "Archipelago")
]
base_title = "Archipelago A Hat in Time Client"

self.ui = AHITManager(self)
self.ui_task = asyncio.create_task(self.ui.async_run(), name="UI")


async def proxy(websocket, path: str = "/", ctx: AHITContext = None):
ctx.endpoint = Endpoint(websocket)
try:
await on_client_connected(ctx)

if ctx.is_proxy_connected():
async for data in websocket:
if DEBUG:
logger.info(f"Incoming message: {data}")

for msg in decode(data):
if msg["cmd"] == "Connect":
# Proxy is connecting, make sure it is valid
if msg["game"] != "A Hat in Time":
logger.info("Aborting proxy connection: game is not A Hat in Time")
await ctx.disconnect_proxy()
break

if ctx.seed_name:
seed_name = msg.get("seed_name", "")
if seed_name != "" and seed_name != ctx.seed_name:
logger.info("Aborting proxy connection: seed mismatch from save file")
logger.info(f"Expected: {ctx.seed_name}, got: {seed_name}")
text = encode([{"cmd": "PrintJSON",
"data": [{"text": "Connection aborted - save file to seed mismatch"}]}])
await ctx.send_msgs_proxy(text)
await ctx.disconnect_proxy()
break

if ctx.connected_msg and ctx.is_connected():
await ctx.send_msgs_proxy(ctx.connected_msg)
ctx.update_items()
continue

if not ctx.is_proxy_connected():
break

await ctx.send_msgs([msg])

except Exception as e:
if not isinstance(e, websockets.WebSocketException):
logger.exception(e)
finally:
await ctx.disconnect_proxy()


async def on_client_connected(ctx: AHITContext):
if ctx.room_info and ctx.is_connected():
await ctx.send_msgs_proxy(ctx.room_info)
else:
ctx.awaiting_info = True


async def proxy_loop(ctx: AHITContext):
try:
while not ctx.exit_event.is_set():
if len(ctx.server_msgs) > 0:
for msg in ctx.server_msgs:
await ctx.send_msgs_proxy(msg)

ctx.server_msgs.clear()
await asyncio.sleep(0.1)
except Exception as e:
logger.exception(e)
logger.info("Aborting AHIT Proxy Client due to errors")


def launch():
async def main():
parser = get_base_parser()
args = parser.parse_args()

ctx = AHITContext(args.connect, args.password)
logger.info("Starting A Hat in Time proxy server")
ctx.proxy = websockets.serve(functools.partial(proxy, ctx=ctx),
host="localhost", port=11311, ping_timeout=999999, ping_interval=999999)
ctx.proxy_task = asyncio.create_task(proxy_loop(ctx), name="ProxyLoop")

if gui_enabled:
ctx.run_gui()
ctx.run_cli()

await ctx.proxy
await ctx.proxy_task
await ctx.exit_event.wait()

Utils.init_logging("AHITClient")
# options = Utils.get_options()

import colorama
colorama.init()
asyncio.run(main())
colorama.deinit()
Loading