minecraft-crawler/README.md
hiina 246d408eca
All checks were successful
/ deploy (push) Successful in 3s
add multimc instance scaffold, actual readme
will have to update the deploy script myself, but I can handle that.
2024-08-23 12:52:04 -06:00

103 lines
3.7 KiB
Markdown

# /vrg/ crawler
If you're just here to use this modpack, see [the website](https://crawler.vrg.party).
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](https://packwiz.infra.link/)-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](https://packwiz.infra.link/tutorials/installing/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.
### Vivecraft Config
TODO
### 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:
```sh
python3 -m venv venv
pip install -r requirements.txt
```
Then run:
```sh
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](https://docker-minecraft-server.readthedocs.io/en/latest/mods-and-plugins/packwiz/)
to (relatively) easily deploy a server using this pack.
One difficulty is that this pack uses [Simple Voice Chat](https://modrinth.com/mod/simple-voice-chat)
which needs UDP 24454 exposed to work. With docker-compose you can use:
```yaml
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](https://vrg.party). We'll see it. Upload your `git patch` output to
pastebin or whatever, if you're autistic enough to do that.