1
0
Fork 0

update readme

This commit is contained in:
khr 2020-04-03 00:00:03 -07:00
parent 2361252b37
commit b8c558513f
1 changed files with 40 additions and 14 deletions

View File

@ -1,20 +1,46 @@
Some Python code for plumbing together a Matrix room and a Minecraft server chat Some Python code for plumbing together a Matrix room and a Minecraft server chat
Setup the app bridge first: This project is a fork of
- Drop ServerWrapper.py and the registration.yaml onto your homeserver. [paftree/matrixcraft-bridge](https://github.com/paftree/matrixcraft-bridge) that
- Add it to your homeserver config, setup ports and keys and whatnot. cleans up the code and adds some new functionality, such as synchronizing Matrix
- Run Serverwrapper.py presence with Minecraft login/logout events.
- On first run, a server config json will be generated. Fill out accordingly and then run again.
Then set up the server wrapper: Setup the application service (bridge part) first:
- Drop ServerWrapper.py into the folder with your Minecraft .jar. - Clone this repo on your homeserver.
- Run once again to generate wrapper.json - Install the packages in `requirements.txt`
- Fill it out. - Add registration.yaml to your homeserver config:
- Start the Minecraft server, see example below ```
app_service_config_files:
- "/path/to/.../registration.yaml"
```
- There are two tokens that need to be added to `registration.yaml`. The
`as_token` should be saved and passed on the command line as
`--appservice_token` to `service.py`.
- Run `service.py` (ideally as e.g. a systemd service).
- `--matrix_server_name` is used to generate user IDs on the local server for
Minecraft users.
- `--matrix_api_port` should be the port you specify in `registration.yaml`.
- `--minecraft_wrapper_port` is the port you wish the service to bind to for
communicating with the Minecraft server. (If the Minecraft server is not
local, you should make sure to open this port in your firewall. Note that it
is not authenticated, so it may not be wise to allow all traffic through
this port.)
Then set up the Minecraft server wrapper:
- Clone this repo on your Matrix server host.
- Install the packages in `requirements.txt`
- Run `wrapper.py` as follows:
`python .\ServerWrapper_v0.1.0.py java -Xmx1024M -Xms1024M -jar minecraft_server.1.11.2.jar` `python wrapper.py --matrix_server example.com --matrix_server_port 5001 java -Xmx1024M -Xms1024M -jar minecraft_server.1.11.2.jar`
The wraper looks in your cwd for anything with "minecraft_server" in the name to know to launch in wrapper mode - `--matrix_server` should be the domain name or IP address which resolves to
your matrix server (could be different from `--matrix_server_name`).
- `--matrix_server_port` is the port you specified as
`--minecraft_wrapper_port` above.
This was hacked together over a weekend, so I make no promises. Quirks:
- You have to invite the appservice user (e.g. `minecraft_bridge`) to a room to
bridge that room with the Minecraft server
- Once the appservice user is invited, if you restart the appservice, you may
have to generate an event (e.g. type a message) to get the appservice to
bridge your room properly.