-
Notifications
You must be signed in to change notification settings - Fork 14
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
Split things up into client and server instructions, and also tell server owners to stop renaming the damn dll!
- Loading branch information
Showing
1 changed file
with
32 additions
and
38 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -1,53 +1,47 @@ | ||
# Garry's Mod Discord Rich Presence | ||
Provides Discord Rich Presence support to Garry's Mod | ||
|
||
In June 2018, Discord broke updating this through HTTP; so any Lua-based implementations of this are no longer possible. However, it is still possible (however impractical for servers) to use Rich Presence by using a binary module. | ||
# GDiscord | ||
#### Discord Rich Presence for Garry's Mod | ||
|
||
This addon provides Discord RPC support for Garry's Mod, through the use of a binary module. For this addon to work, a Lua script is required on servers to sync information, and a binary module is required on clients. | ||
|
||
In June 2018, Discord broke updating this through HTTP; so any Lua-based implementations of this are no longer possible. However, it is still possible (however impractical for servers) to use Rich Presence by using a binary module. | ||
|
||
## For Clients | ||
Download the latest version of the GDiscord module from the [releases page](https://github.com/fluffy-servers/gmod-discord-rpc/releases). | ||
The module you need depends on what OS and version you're running (eg. Windows on 32-bit should download **gmcl_gdiscord_win32.dll**). If you're running the 64-bit beta, make sure you download the 64.dll! | ||
|
||
## Installation | ||
### Binary Module (Clients) | ||
Clients need to put the *gmcl_gdiscord_\*.dll* corresponding to the game's version in **lua/bin/** | ||
Copy this into **lua/bin/**. That's all! | ||
|
||
### LUA Addon (Servers) | ||
Servers need to install a Lua script that syncs the game details to Discord. | ||
This can optionally be installed by players for support of single player or P2P games. | ||
With this module installed, your Discord status should automatically update when playing on supported servers. | ||
|
||
This .lua file needs to go in lua/autorun/client/ | ||
Installing this file on the server will have no effect on clients who do not have the required module installed. | ||
## For Servers | ||
Please note that for this to work, **all** clients *will* need to install the binary module. | ||
|
||
## Configuration | ||
### Setting up an Application | ||
The first step is to set up a Discord application so you can slightly customise the display | ||
Download the latest version of cl_discord.lua from the [releases page](https://github.com/fluffy-servers/gmod-discord-rpc/releases). | ||
|
||
Copy this into **lua/autorun/client**. | ||
|
||
### Configuration | ||
For best results, server owners need to edit cl_discord.lua for server-specific configuration. | ||
|
||
You ***should not*** edit or rename the binary module. Please keep this as gdiscord, so clients can use one module across all supported servers! | ||
|
||
#### Setting up an Application | ||
The first step is to set up a Discord application so you can slightly customise the display. This application contains the map images that will be displayed in Discord. | ||
|
||
Create an application over at https://discordapp.com/developers/ | ||
|
||
Go into Rich Presence > Art Assets and upload images of each map you want, along with an optional default image. Ensure that each map is named correctly. | ||
|
||
Copy the Client ID from General Information. | ||
|
||
### Configuration | ||
#### Lua File | ||
Open up the .lua file and change the following variables as needed: | ||
- *discord_id* should be the Client ID you obtained earlier | ||
- *refresh_time* should be how frequently you want the display to update | ||
|
||
### Default Map Image | ||
In order to display a default map image, you'll need to painfully create a list of which maps you have icons for. | ||
Put them into the *map_list* table. | ||
|
||
Once that's done, ensure that *map_restrict* is set to true. Change *map_default* to the name of whatever the default icon should be. | ||
|
||
## Building the .dll | ||
### Windows | ||
1. Open Visual Studio 2019 and clone this repository | ||
2. The default configuration should be "x86-Release" for the 32bit version\ | ||
If you want the 64bit version select the "x64-Release" configuration | ||
3. Select `Build` -> `Build All` | ||
4. The .dll should now be in `gmod-discord-rpc/cpp/build/\*-Release/` | ||
### Linux | ||
1. Make sure you have git, cmake, and gcc installed | ||
2. Open a terminal and run | ||
```git clone https://github.com/fluffy-servers/gmod-discord-rpc --recursive | ||
cd gmod-discord-rpc/cpp | ||
mkdir build && cd build | ||
cmake .. && cmake --build . | ||
``` | ||
3. The .dll should now be in `gmod-discord-rpc/cpp/build/` | ||
#### Default Map Image | ||
To display a default map image, the script needs to know which maps you have specific icons for. There's no way for the Lua script to know what you've uploaded to Discord, so this is a manual process. Sorry. | ||
|
||
Put all the maps you have images for into the *map_list* table. Once that's done, change *map_restrict* to true, and set *map_default* to the name of whatever the default icon should be. | ||
|
||
**If you have images uploaded for every map in your rotation, you don't need to worry about this step.** |