summary refs log tree commit diff homepage
path: root/README.md
blob: 80b6b8cbbdde1394c89c1269a63fd8f458412b5f (plain) (blame)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
# shulker

[![Build Status](https://david-dm.org/destruc7i0n/shulker.svg)](https://david-dm.org/destruc7i0n/shulker)
[![Build Status](https://travis-ci.org/destruc7i0n/shulker.svg?branch=master)](https://travis-ci.org/destruc7i0n/shulker)

> Connects [Discord](https://discordapp.com/) and [Minecraft](https://minecraft.net) Servers by sending messages back and forth.

## Example
![discord-irc](http://i.giphy.com/6yj4FRw3XZt6M.gif)

## Installation and usage

In your Minecraft server.properties, make sure you have:
```
enable-rcon=true
rcon.password=<your password>
rcon.port=<1-65535>
```

Run the following on your server hosting (in a screen, and make sure to replace your URL and your log directory location):

``` sh
tail -F /PATH_TO_MINECRAFT_INSTALL/logs/latest.log | grep --line-buffered ": <" | while read x ; do echo -ne $x | curl -X POST -d @- https://YOUR_URL/minecraft/hook ; done
```

Clone repository onto a server, edit ```config.json``` and change any options, and then,
```bash
In the repository folder:
$ npm install
$ npm start
```
You can also easily Deploy to Heroku or Bluemix.

[![Deploy to Heroku](https://www.herokucdn.com/deploy/button.png)](https://heroku.com/deploy)
[![Deploy to Bluemix](https://bluemix.net/deploy/button.png)](https://bluemix.net/deploy?repository=https://github.com/destruc7i0n/shulker)


### Configuration
```js
{
    "PORT": 8000, # Port you want to run the webserver for the hook on
    "DISCORD_EMAIL": "example@example.com", # discord email
    "DISCORD_PASSWORD": "password123", # discord password
    "DISCORD_CHANNEL": "general", # channel for discord bot
    "MINECRAFT_SERVER_RCON_IP": "example.com", # minecraft server ip (make sure you have enabled rcon)
    "MINECRAFT_SERVER_RCON_PORT": <1-65535>, # minecraft server rcon port 
    "MINECRAFT_SERVER_RCON_PASSWORD": "<your password>", # minecraft server rcon password
    "WEBHOOK": "/minecraft/hook", # web hook, where to send the log to
    "REGEX_MATCH_CHAT_MC": "\\[Server thread/INFO\\]: <(.*)> (.*)", # what to match for chat (best to leave as default)
    "REGEX_IGNORED_CHAT": "packets too frequently", # what to ignore, you can put any regex for swear words for example and it will be ignored
    "DEBUG": false # dev debugging
}
```


## Tests
Run the tests with:
```bash
$ npm test
```

## License

ISC. See `LICENSE`.