also ignore some of the shit so the multimc and polymc and .mrpack automation works.
4.4 KiB
/vrg/ crawler
If you're just here to use this modpack, see the website.
This is all the glue code and infrastructure to make the pack work. Read on if you want the gory details.
Goals
- Turn minecraft into an acceptable VR co-op dungeon crawler.
- Smooth over as many of the implementation details (including the fact it's a
minecraft mod pack) as much as possible.
- Auto-update clients automatically from the server config
- Auto-update the canonical server from this repo.
- Patch around the awful steamVR bindings setup experience.
How It Works
This repo is primarily a packwiz-based mod pack. All the mods are pinned to specific Modrinth versions and the configs (client and server) are versioned directly in the modpack. A deploy script on the webserver syncs this repo state to https://crawler.vrg.party/pack.toml.
MultiMC instance
The MultiMC / PolyMC / Prism Launcher compatible instance zip is put together
with minimal configuration in the multimc-instance
dir. The instance uses
packwiz-installer
as a pre-launch task to fetch the pack.toml file and actually download all the
mods for you, including updating/removing mods as needed.
The pack currently also autojoins the crawler.vrg.party server on launch. I think this is nice and saves a few clicks, but could be convinced otherwise.
Default Minecraft / Vivecraft Config
We include default options.txt
and optionsviveprofiles.txt
which unfuck some of
the conflicting keybinds and bad default Vivecraft settings, and have Vivecraft
radial menu bindings for some of the need-to-have things in the mod pack (like
the voice chat UI and the skills tree).
These are loaded by the Your Options Shall Be
Respected(YOSBR) mod, only if you don't have a
current config already (different than the packwiz behavior to overwrite
whatever's there). Which is both good and bad; if we find better default
configs, clients will have to go in and delete the options.txt
and
optionsviveprofiles.txt
files to get the updated versions manually, but
users can have their own setup if they want.
SteamVR Bindings
TODO
Mod Descriptions
Somehow, there is no existing tool that really shows you what's in a giant modpack like this one. Sure you can stare at the multimc mods UI, or even look at the flat list of mods in a modrinth modpack, but that's not very helpful; it's at best an alphabetical list, all the library mods you don't really care about are mixed in there, and it's hard to tell what's actually important.
So, I made collect-mod-descriptions.py
to gather and update mod descriptions
into a nice html page. It involves manually categorizing all the mods by their
modrinth slug, which is a bit of a pain, but it's way more useful than a flat
list (or even the author-provided modrinth tags, which aren't that good).
To run it, first setup the environment:
python3 -m venv venv
pip install -r requirements.txt
Then run:
python3 collect-mod-descriptions.py mods mods.html
The script will complain if some of the mods in packwiz aren't tracked in the python file itself (for manual categorization).
Server
Since this is packwiz, you can use itzg Minecraft Docker image to (relatively) easily deploy a server using this pack.
One difficulty is that this pack uses Simple Voice Chat which needs UDP 24454 exposed to work. With docker-compose you can use:
services:
mc:
ports:
- 25565:25565 # minecraft TCP
- 24454:24454/udp # simple voice chat UDP
to do this.
Web Deployment
I set up a forgejo workflow to run on push to master. The workflow just sends an HTTP POST to the webserver, where I set up a CGI script (through nginx and fcgiwrap) that does the dirty work (git pull, update the multimc zip file); I didn't want to give direct SSH access to the server for this since it's not well isolated. Janky setup, but works for me.
Contributing
If you'd like to contribute to this modpack or suggest changes, post in the
thread. We'll see it. Upload your git patch
output to
pastebin or whatever, if you're autistic enough to do that.