Skip to content
This repository has been archived by the owner on Sep 14, 2022. It is now read-only.

Latest commit

 

History

History
86 lines (64 loc) · 3.53 KB

README.md

File metadata and controls

86 lines (64 loc) · 3.53 KB

Deprecated.

This project is now archived due to Discord deprecating the Discord-RPC SDK in favor of the Discord GameSDK.

A new project will be created soon.

A detailed guide to getting a functional custom presence with buttons on Discord!

Table of contents

FAQ

  1. Q. What is a custom presence? A. A custom presence is essentially what the name states; a customizable presence that is displayed on your Discord profile.

Custom Presence Example

  1. Q. Is it against the ToS? A. No, custom presences are a part of Discord and are not against any rule of Discord.

(you can read more about Discord's rules here: Terms of Service, Guidelines)

Get started

Update

The code is now available for simple download here.

To begin with, head over to Discord's developer page (https://discord.com/developers/applications) and create a new application. However you decide to name it is the name that will appear on your presence. My application is named "Helix", thus the displayed game name will be "Helix".

RPC Name Example

Assets

Next you will go to the Art Assets tab under Rich Presence (figure A1) and add your large image (A2) and small image (A3) to the rich presence assets and give them a name (A4). Keep in mind! All images need to be a minimum of 512 x 512 pixels.

A1

Figure A1

A2

Figure A2

A3

Figure A3

A4

Figure A4

Code

Now that the image part is done we can get to coding!

In a folder create an index.js file with the following contents.

var rpc = require("discord-rpc")
const client = new rpc.Client({ transport: 'ipc' })
client.on('ready', () => {
    client.request('SET_ACTIVITY',
    {pid: process.pid, activity : {
	details : "your-text",
	assets : {
		large_image : "your-large-image", 
		large_text : "your-large-text" },
		buttons : [{label : "Button1" , url : "Link1"}, 
		{label : "Button2",url : "Link2"}]}
	})
})

client.login({ clientId : "ApplicationID" }).catch(console.error);

Replace the details field your-text with the text you want to be displayed under the game name. details field

Button1 is the name of the first button and Link1 is the link activated when clicking the first button on the presence. Button2 and Link2 are the variables of the second button on the presence. Fill the fields accordignly.

The ApplicationID field is where you have to insert your application's ID found on the General Information tab of the application. ID

For the next step you can download the package.json on this repository. After that you can install the needed dependencies using npm i discord-rpc.

The last step is launching it. You can do that by typing node index.js in a terminal window. The presence will run for as long as the terminal and Discord are running. To stop it, close the terminal.

Happy coding!

Star this repo if it helped you!