-
Notifications
You must be signed in to change notification settings - Fork 0
Expand file tree
/
Copy pathbot.js
More file actions
75 lines (61 loc) · 2.13 KB
/
Copy pathbot.js
File metadata and controls
75 lines (61 loc) · 2.13 KB
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
65
66
67
68
69
70
71
72
73
74
75
const Discord = require('discord.js');
const client = new Discord.Client();
const config = require("./config.json")
const GALORANTROLE = "719978451787972720"
const STREAMINGROLE = "721142930525519903"
client.once('ready', () => {
console.log('Ready!');
});
client.login(config.token);
client.on('message', message => {
if (message.content === '!ping') {
message.channel.send('Pong.');
}
});
client.on('presenceUpdate', (oldPresence, newPresence) => {
if (!newPresence.member || !newPresence.member._roles){
return
}
if (newPresence.member.id == "628755933366845451"){
return
}
if (!newPresence.member._roles.includes(GALORANTROLE)){
return;
}
console.log('Presence update for', newPresence.member.displayName)
if (isUserStreaming(newPresence) && !newPresence.member._roles.includes(STREAMINGROLE)){
onUserStartStreaming(newPresence.member)
} else if (!isUserStreaming(newPresence) && newPresence.member._roles.includes(STREAMINGROLE)){
onUserStopStreaming(newPresence.member);
}
// if ((!oldPresence || !isUserStreaming(oldPresence)) && isUserStreaming(newPresence)) {
// onUserStartStreaming(newPresence.member)
// } else if ((!oldPresence || isUserStreaming(oldPresence)) && !isUserStreaming(newPresence)){
// onUserStopStreaming(newPresence.member)
// }
});
/**
* Checks if the user is streaming
* @param {Discord.Presence} presence - A Discord presence object
*/
function isUserStreaming(presence) {
const activities = presence.activities
if (!activities || activities.length === 0) {
return false;
}
//Loops over the activities status's to see what it is
for (let index = 0; index < activities.length; index++) {
const activity = activities[index];
if (activity.type === "STREAMING")
return true;
}
return false;
}
function onUserStartStreaming(member){
console.log('Giving role to ', member.displayName)
member.roles.add(STREAMINGROLE)
}
function onUserStopStreaming(member){
console.log('Taking role from ', member.displayName)
member.roles.remove(STREAMINGROLE)
}