resetting linux lol
diff --git a/src/events/webhookUpdate.ts b/src/events/webhookUpdate.ts
new file mode 100644
index 0000000..a20608c
--- /dev/null
+++ b/src/events/webhookUpdate.ts
@@ -0,0 +1,78 @@
+import humanizeDuration from 'humanize-duration';
+export const event = 'webhookUpdate'
+
+export async function callback(client, channel) {
+ try {
+ const { getAuditLog, log, NucleusColors, entry, renderUser, renderChannel, renderDelta } = client.logger
+ let auditLogCreate = getAuditLog(channel.guild, 'WEBHOOK_CREATE');
+ let auditLogUpdate = getAuditLog(channel.guild, 'WEBHOOK_UPDATE');
+ let auditLogDelete = getAuditLog(channel.guild, 'WEBHOOK_DELETE');
+ [auditLogCreate, auditLogUpdate, auditLogDelete] = await Promise.all([auditLogCreate, auditLogUpdate, auditLogDelete]);
+ let auditCreate = auditLogCreate.entries.filter(entry => entry.target.channelId == channel.id).first();
+ let auditUpdate = auditLogUpdate.entries.filter(entry => entry.target.channelId == channel.id).first();
+ let auditDelete = auditLogDelete.entries.filter(entry => entry.target.channelId == channel.id).first();
+ if (!auditCreate && !auditUpdate && !auditDelete) return;
+ let audit = auditCreate;
+ let action = "Create";
+ let list = {} as any;
+ if (auditUpdate && auditUpdate.createdTimestamp > audit.createdTimestamp) {
+ let {before, after} = auditUpdate.changes.reduce(
+ (acc, change) => { acc.before[change.key] = change.old; acc.after[change.key] = change.new; return acc; },
+ {before: {}, after: {}}
+ );
+ if (before.name !== after.name) list['name'] = entry([before.name, after.name], `${before.name} -> ${after.name}`)
+ if (before.channel_id !== after.channel_id) list['channel'] = entry([before.channel_id, after.channel_id], renderChannel(await client.channels.fetch(before.channel_id)) + ` -> ` + renderChannel(await client.channels.fetch(after.channel_id)))
+ if (!(Object.keys(list)).length) return;
+ list.created = entry(auditUpdate.target.createdTimestamp, renderDelta(auditUpdate.target.createdTimestamp));
+ list.edited = entry(after.editedTimestamp, renderDelta(new Date().getTime()));
+ list.editedBy = entry(auditUpdate.executor.id, renderUser(auditUpdate.executor));
+ audit = auditUpdate;
+ action = "Update"
+ } else if (auditDelete && auditDelete.createdTimestamp > audit.createdTimestamp) {
+ let {before, after} = auditDelete.changes.reduce(
+ (acc, change) => { acc.before[change.key] = change.old; acc.after[change.key] = change.new; return acc; },
+ {before: {}, after: {}}
+ );
+ list = {
+ name: entry(before.name, `${before.name}`),
+ channel: entry(before.channel_id, renderChannel(await client.channels.fetch(before.channel_id))),
+ created: entry(auditDelete.target.createdTimestamp, renderDelta(auditDelete.target.createdTimestamp)),
+ deleted: entry(new Date().getTime(), renderDelta(new Date().getTime())),
+ deletedBy: entry(auditDelete.executor.id, renderUser((await channel.guild.members.fetch(auditDelete.executor.id)).user)),
+ }
+ audit = auditDelete;
+ action = "Delete"
+ } else {
+ let {before, after} = auditDelete.changes.reduce(
+ (acc, change) => { acc.before[change.key] = change.old; acc.after[change.key] = change.new; return acc; },
+ {before: {}, after: {}}
+ );
+ list = {
+ name: entry(before.name, `${before.name}`),
+ channel: entry(before.channel_id, renderChannel(await client.channels.fetch(before.channel_id))),
+ createdBy: entry(auditCreate.executor.id, renderUser((await channel.guild.members.fetch(auditCreate.executor.id)).user)),
+ created: entry(new Date().getTime(), renderDelta(new Date().getTime())),
+ }
+ }
+ let cols = {
+ "Create": "green",
+ "Update": "yellow",
+ "Delete": "red",
+ }
+ let data = {
+ meta: {
+ type: 'webhook' + action,
+ displayName: `Webhook ${action}d`,
+ calculateType: 'webhookUpdate',
+ color: NucleusColors[cols[action]],
+ emoji: "WEBHOOK." + action.toUpperCase(),
+ timestamp: new Date().getTime()
+ },
+ list: list,
+ hidden: {
+ guild: channel.guild.id
+ }
+ } // TODO
+ log(data);
+ } catch(e) { console.log(e) }
+}