Fork of Archipelago Multi-Game Randomizer and Server that runs on https://ap.hollymcfarland.com
* Object-Oriented base changes for web-ui prep
* remove debug raise
* optimize broadcast to serialize once
* Implement WebUI socket, static assets, and classes
- Still need to wrap logging functions and send output to UI
- UI commands are successfully being sent to the server
* GUI operational. Wrap logging functions, implement server address selection on GUI, automatically launch web browser when client websocket is served
* Update MultiServer status when a user disconnects / reconnects
* Implement colored item and hint checks, improve GUI readability
* Fix improper formatting on received items
* Update SNES connection status on disconnect / reconnect. Implement itemFound, prevent accidentally printing JS objects
* Minor text change for itemFound
* Fixed a very wrong comment
* Fixed client commands not working, fixed un-helpful error messages appearing in GUI
* Fix a bug causing a failure to connect to a multiworld server if a previously existing cached address was present and the client was loaded without an address passed in
* Convert WebUI to React /w Redux. WebSocket communications not yet operational.
* WebUI fully converted to React / Redux.
- Websocket communication operational
- Added a button to connect to the multiserver which appears only when a SNES is connected and a server connection is not active
* Restore some features lost in WebUI
- Restore (found) notification on hints if the item has already been obtained
- Restore (x/y) indicator on received items, which indicates the number of items the client is waiting to receive from the client in a queue
* Fix a grammatical UI big causing player names to show only an apostrophe when possessive
* Add support for multiple SNES Devices, and switching between them
* freeze support for client
* make sure flask works when frozen
* UI Improvements
- Hint messages now actually show a found status via ✔ and ❌ emoji
- Active player name is always a different color than other players (orange for now)
- Add a toggle to show only entries relevant to the active player
- Added a WidgetArea
- Added a notes widget
* Received items now marked as relevant
* Include production build for deployment
* Notes now survive a browser close. Minimum width applied to monitor to prevent CSS issues.
* include webUi folder in setup.py
* Bugfixes for Monitor
- Fix a bug causing the monitor window to grow beyond it's intended content limit
- Reduced monitor content limit to 200 items
- Ensured each monitor entry has a unique key
* Prevent eslint from yelling at me about stupid things
* Add button to collapse sidebar, press enter on empty server input to disconnect on purpose
* WebUI is now aware of client disconnect, message log limit increased to 350, fix !missing output
* Update WebUI to v2.2.1
- Added color to WebUI for entrance-span
- Make !missing show total count at bottom of list to match /missing behavior
* Fix a bug causing clients version <= 2.2.0 to crash when anyone asks for a hint
- Also fix a bug in the WebUI causing the entrance location to always show as "somewhere"
* Update WebUI color palette (this cost me $50)
* allow text console input alongside web-ui
* remove Flask
a bit overkill for what we're doing
* remove jinja2
* Update WebUI to work with new hosting mechanism
* with flask gone, we no longer need subprocess shenanigans
* If multiple web ui clients try to run, at least present a working console
* Update MultiClient and WebUI to handle multiple clients simultaneously.
- The port on which the websocket for the WebUI is hosted is not chosen randomly from 5000 - 5999. This port is passed to the browser so it knows which MultiClient to connect to
- Removed failure condition if a web server is already running, as there is no need to run more than one web server on a single system. If an exception is thrown while attempting to launch a web server, a check is made for the port being unavailable. If the port is unavailable, it probably means the user is launching a second MultiClient. A web browser is then opened with a connection to the correct webui_socket_port.
- Add a /web command to the MultiClient to repoen the appropriate browser window and get params in case a user accidentally closes the tab
* Use proper name for WebUI
* move webui into /data with other data files
* make web ui optional
This is mostly for laptop users wanting to preserve some battery, should not be needed outside of that.
* fix direct server start
* re-add connection timer
* fix indentation
Co-authored-by: Chris <chris@legendserver.info>
|
||
---|---|---|
.github | ||
data | ||
test | ||
.gitignore | ||
Adjuster.py | ||
AdjusterMain.py | ||
BaseClasses.py | ||
Bosses.py | ||
Dungeons.py | ||
ER_hint_reference.txt | ||
EntranceRandomizer.py | ||
EntranceShuffle.py | ||
Fill.py | ||
Gui.py | ||
GuiUtils.py | ||
InvertedRegions.py | ||
ItemList.py | ||
Items.py | ||
LICENSE | ||
Main.py | ||
ModuleUpdate.py | ||
MultiClient.py | ||
MultiMystery.py | ||
MultiServer.py | ||
Mystery.py | ||
NetUtils.py | ||
Options.py | ||
OverworldGlitchRules.py | ||
Patch.py | ||
Plando.py | ||
Plandomizer_Template.txt | ||
README.md | ||
Regions.py | ||
Rom.py | ||
Rules.py | ||
Text.py | ||
Utils.py | ||
WebUiClient.py | ||
WebUiServer.py | ||
appveyor.yml | ||
easy.yaml | ||
host.yaml | ||
icon.ico | ||
inno_setup.iss | ||
meta.yaml | ||
pytest.ini | ||
requirements.txt | ||
setup.py |
README.md
Berserker's Multiworld
This is a complete fork of Bonta's Multiworld V31. It is a drop-in replacement with everything from Bonta's Multiworld included. You can find a guide here: https://docs.google.com/document/d/1r7qs1-MK7YbFf2d-mEUeTy2wHykIf1ALG9pLtVvUbSw/edit# Or use the Wiki button at the top
Additions/Changes
Project
- Available in precompiled form and guided setup for Windows 64Bit on Releases page.
- Compatible with Python 3.7 and 3.8. Potentially future versions as well.
- Update modules if they are too old, preventing a crash when trying to connect among potential other issues
- Autoinstall missing modules
- Allow newer versions of modules than specified, as they will usually not break compatibility
- Support for V31 extendedmsu
- Has support for binary patching to allow legal distribution of multiworld rom files
- Various performance improvements (over 100% faster in most cases)
- Various fixes
- Overworld Glitches Logic
- Newer Entrance Randomizer Logic, allowing more potential item and boss locations
- completely redesigned command interface, with
!help
and/help
MultiMystery.py
- Allows you to generate a Multiworld with individual player mystery weights. Since weights can also be set to 100%, this also allows for individual settings for each player in a regular multiworld. Basis is a .yaml file that sets these weights. You can find an easy.yaml in this project folder to get started.
- Additional instructions are at the start of the file. Open with a text editor.
- Configuration options in the host.yaml file.
MultiServer.py
- Supports automatic port-forwarding, can be enabled in host.yaml
- improved
!players
command, mentioning how many players are currently connected of how many expected and who's missing - /forfeit Playername now works when the player is not currently connected
- Added
/hint
and!hint
, configuration in host.yaml and description in help - various commands, like /send and /hint use "fuzzy text matching", no longer requiring you to enter a location, player name or item name perfectly
Mystery.py
- Defaults to generating a non-race ROM (Bonta's only makes race ROMs at this time) If a race ROM is desired, pass --create-race as argument to it
- When an error is generated due to a broken .yaml file, it now mentions in the error trace which file, line and character is the culprit
- Option for progressive items, allowing you to turn them off (see easy.yaml for more info)
- Rom-Option for extendedmsu (see easy.yaml for more info)
- Option for "timer"
- Option for "dungeon_counters", allowing you to configure the dungeon item counter
- Option for "glitch_boots", allowing to run glitched modes without automatic boots
- Supports new Meta-Mystery mode. Read meta.yaml for details.
- Added
dungeonssimple
anddungeonsfull
ER modes
MultiClient.py
- Awaits a QUsb2Snes connection when started, latching on when available
- completely redesigned command interface, with
!help
and/help
- Running it with a patch file will patch out the multiworld rom and then automatically connect to the host that created the multiworld
- Cheating is now controlled by the server and can be disabled through host.yaml
- Automatically starts QUsb2Snes, if it isn't running
- Better reconnect to both snes and server