Compare commits
No commits in common. "171bc65bf4f5f9694431456933d9bcf0dcaa8a26" and "4dc8fb19fb9456ad968c39ddc38cc29843d24e9b" have entirely different histories.
171bc65bf4
...
4dc8fb19fb
@ -1,95 +0,0 @@
|
|||||||
var client = require("./client");
|
|
||||||
var config = require("./config");
|
|
||||||
var app = require("./www");
|
|
||||||
var DataStore = require("./datastore");
|
|
||||||
|
|
||||||
var ds = new DataStore("activity");
|
|
||||||
|
|
||||||
|
|
||||||
app.get("/detect/:userid", (req, res) => {
|
|
||||||
res.sendFile(process.cwd() + "/track-image.png");
|
|
||||||
if (req.headers["user-agent"].includes("Discordbot")) return;
|
|
||||||
onActivity(req.params.userid);
|
|
||||||
});
|
|
||||||
|
|
||||||
|
|
||||||
client.on("messageCreate", m => m.guildId == config.guild && onActivity(m.author.id));
|
|
||||||
client.on("interactionCreate", i => i.guildId == config.guild && onActivity(i.user.id));
|
|
||||||
client.on("typingStart", t => t.guild?.id == config.guild && onActivity(t.user.id));
|
|
||||||
client.on("guildMemberAdd", m => m.guild.id == config.guild && onActivity(m.user.id));
|
|
||||||
client.on("messageReactionAdd", (r, user) => r.message?.guild?.id == config.guild && onActivity(user.id));
|
|
||||||
client.on("messageReactionRemove", (r, user) => r.message?.guild?.id == config.guild && onActivity(user.id));
|
|
||||||
client.on("messageUpdate", (oldMessage, newMessage) => (oldMessage.editedAt != newMessage.editedAt) && onActivity(newMessage.author.id));
|
|
||||||
|
|
||||||
|
|
||||||
async function onActivity(user_id) {
|
|
||||||
if (!user_id) return;
|
|
||||||
ds.set(user_id, Date.now());
|
|
||||||
if (ds.get(user_id + "deactivated")) {
|
|
||||||
reactivateMember(client.guilds.resolve(config.guild).members.resolve(user_id));
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
module.exports.interval = setInterval(() => {
|
|
||||||
var guild = client.guilds.resolve(config.guild);
|
|
||||||
if (!guild) return;
|
|
||||||
guild.members.cache.filter(m => !m.user.bot).forEach(member => {
|
|
||||||
let lastActivityTime = ds.get(member.user.id);
|
|
||||||
if (!lastActivityTime) return;
|
|
||||||
if (Date.now() - lastActivityTime > 1000*60*60*24) { // if last activity > 24 hours ago
|
|
||||||
if (!ds.get(member.id + "deactivated"))
|
|
||||||
deactivateMember(member);
|
|
||||||
}
|
|
||||||
});
|
|
||||||
}, 60*60*1000); // every hour i guess
|
|
||||||
|
|
||||||
|
|
||||||
async function deactivateMember(member) {
|
|
||||||
//if (ds.get(member.id + "deactivated")) return "member is already deactivated";
|
|
||||||
await member.roles.add(config.inactive_role);
|
|
||||||
ds.set(member.id + "deactivated");
|
|
||||||
|
|
||||||
var magic_channel = client.channels.resolve(ds.get(member.id + "magicchannelid"));
|
|
||||||
if (!magic_channel) {
|
|
||||||
magic_channel = await member.guild.channels.create("inactive", {
|
|
||||||
permissionOverwrites: [
|
|
||||||
{
|
|
||||||
id: this.guild.roles.everyone,
|
|
||||||
deny: "VIEW_CHANNEL"
|
|
||||||
},
|
|
||||||
{
|
|
||||||
id: client.user,
|
|
||||||
allow: "VIEW_CHANNEL"
|
|
||||||
},
|
|
||||||
{
|
|
||||||
id: this.user,
|
|
||||||
allow: "VIEW_CHANNEL"
|
|
||||||
}
|
|
||||||
]
|
|
||||||
});
|
|
||||||
ds.put(member.id + "magicchannelid", magic_channel.id);
|
|
||||||
} else {
|
|
||||||
magic_channel.permissionOverwrites.edit(member, {"VIEW_CHANNEL": true});
|
|
||||||
}
|
|
||||||
|
|
||||||
var magic_channel_message = await magic_channel.messages.fetch(ds.get(member.id + "magicchannelmessage"));
|
|
||||||
if (!magic_channel_message) {
|
|
||||||
magic_channel_message = await magic_channel.send(`${config.base_uri}/detect/${this.user.id}?${Math.random()}`);
|
|
||||||
ds.put(member.id + "magicchannelmessage", magic_channel_message.id)
|
|
||||||
} else {
|
|
||||||
await magic_channel_message.edit(`${config.base_uri}/detect/${this.user.id}?${Math.random()}`);
|
|
||||||
}
|
|
||||||
|
|
||||||
}
|
|
||||||
|
|
||||||
async function reactivateMember(member) {
|
|
||||||
//if (!ds.get(member.id + "deactivated")) return "member is not deactivated";
|
|
||||||
await member.roles.remove(config.inactive_role);
|
|
||||||
ds.del(member.id + "deactivated");
|
|
||||||
var magic_channel = client.channels.resolve(ds.get(member.id + "magicchannelid"));
|
|
||||||
if (magic_channel) magic_channel.permissionOverwrites.edit(member, {"VIEW_CHANNEL": false});
|
|
||||||
}
|
|
||||||
|
|
||||||
module.exports.deactivateMember = deactivateMember;
|
|
||||||
module.exports.reactivateMember = reactivateMember;
|
|
@ -7,7 +7,6 @@ module.exports = {
|
|||||||
admin_role: "776899554603565116",
|
admin_role: "776899554603565116",
|
||||||
human_role: "672956630962274306",
|
human_role: "672956630962274306",
|
||||||
bot_role: "673671040010027034",
|
bot_role: "673671040010027034",
|
||||||
inactive_role: "892869309603389500",
|
|
||||||
eval_undefined_emoji: "707729833601531935",
|
eval_undefined_emoji: "707729833601531935",
|
||||||
mi_emoji: "887931046086185060",
|
mi_emoji: "887931046086185060",
|
||||||
ki_emoji: "887935846710394910",
|
ki_emoji: "887935846710394910",
|
||||||
|
3
index.js
3
index.js
@ -12,5 +12,4 @@ require('./pixiv-embedder');
|
|||||||
require('./漢字ゲーム');
|
require('./漢字ゲーム');
|
||||||
require('./translate2');
|
require('./translate2');
|
||||||
require('./world-clock');
|
require('./world-clock');
|
||||||
require('./buttonthing');
|
require('./buttonthing');
|
||||||
require("./activitytracker");
|
|
@ -42,7 +42,7 @@ module.exports = class MagicChannel extends EventEmitter{
|
|||||||
}).then(channel => {
|
}).then(channel => {
|
||||||
this.channel = channel;
|
this.channel = channel;
|
||||||
ds.put(this.user.id + "channel", channel.id);
|
ds.put(this.user.id + "channel", channel.id);
|
||||||
channel.send(`${config.base_uri}/${this.user.id}?${Math.random()}`).then(message => {
|
channel.send(`${config.base_uri}/${this.user.id}`).then(message => {
|
||||||
ds.put(this.user.id + "message", message.id);
|
ds.put(this.user.id + "message", message.id);
|
||||||
});
|
});
|
||||||
});
|
});
|
||||||
|
Loading…
Reference in New Issue
Block a user