Merge pull request #63 from JsSucks/eventhook

Merge
This commit is contained in:
Alexei Stukov 2018-02-02 15:00:50 +02:00 committed by GitHub
commit aec27f2493
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
15 changed files with 460 additions and 15 deletions

View File

@ -10,21 +10,24 @@
import { DOM, BdUI } from 'ui'; import { DOM, BdUI } from 'ui';
import BdCss from './styles/index.scss'; import BdCss from './styles/index.scss';
import { Events, CssEditor, Globals, PluginManager, ThemeManager, ModuleManager } from 'modules'; import { Events, CssEditor, Globals, PluginManager, ThemeManager, ModuleManager, WebpackModules } from 'modules';
import { ClientLogger as Logger } from 'common'; import { ClientLogger as Logger } from 'common';
class BetterDiscord { class BetterDiscord {
constructor() { constructor() {
window.events = Events;
window.wpm = WebpackModules;
DOM.injectStyle(BdCss, 'bdmain'); DOM.injectStyle(BdCss, 'bdmain');
Events.on('global-ready', this.globalReady.bind(this)); Events.on('global-ready', this.globalReady.bind(this));
} }
async init() { async init() {
await ModuleManager.initModules();
await PluginManager.loadAllPlugins(); await PluginManager.loadAllPlugins();
await ThemeManager.loadAllThemes(); await ThemeManager.loadAllThemes();
ModuleManager.initModules();
Events.emit('ready'); Events.emit('ready');
Events.emit('discord-ready');
} }
globalReady() { globalReady() {

View File

@ -0,0 +1,143 @@
/**
* BetterDiscord WebpackModules Module
* Copyright (c) 2015-present Jiiks/JsSucks - https://github.com/Jiiks / https://github.com/JsSucks
* All rights reserved.
* https://betterdiscord.net
*
* This source code is licensed under the MIT license found in the
* LICENSE file in the root directory of this source tree.
*/
import EventListener from './eventlistener';
import { Utils } from 'common';
import Events from './events';
import {
MESSAGE_CREATE
} from '../structs/socketstructs';
export default class extends EventListener {
bindings() {
this.hook = this.hook.bind(this);
}
get eventBindings() {
return [
{ id: 'discord-ready', callback: this.hook }
];
}
hook() {
}
get eventsModule() {
}
emit(e, action, data) {
switch(e) {
case 'dispatch':
return this.dispatch(action, data);
}
}
dispatch(e, d) {
Events.emit('raw-event', { type: e, data: d });
switch (e) {
case this.actions.READ:
Events.emit('discord-ready');
break;
case this.actions.RESUMED:
Events.emit('discord-resumed');
break;
case this.actions.TYPING_START:
Events.emit('discord-event', {
type: e,
channelId: d.channel_id,
userId: d.user_id
});
break;
case this.actions.MESSAGE_CREATE:
Events.emit('discord-event', { type: e, data: new MESSAGE_CREATE(d) });
break;
case 'k':
Events.emit('discord-event', {
});
break;
case this.actions.ACTIVITY_START:
Events.emit('discord-event', this.construct(e, d));
break;
}
}
get actions() {
return {
READY: 'READY', // Socket ready
RESUMED: 'RESUMED', // Socket resumed
TYPING_START: 'TYPING_START', // User typing start
ACTIVITY_START: 'ACTIVITY_START', // ??
MESSAGE_CREATE: 'MESSAGE_CREATE', // New message
MESSAGE_UPDATE: 'MESSAGE_UPDATE', // Edit
MESSAGE_DELETE: 'MESSAGE_DELETE', // Message deleted
MESSAGE_DELETE_BULK: 'MESSAGE_DELETE_BULK', // Bulk messages deleted
MESSAGE_ACK: 'MESSAGE_ACK', // Message fetch
MESSAGE_REACTION_ADD: 'MESSAGE_REACTION_ADD', // eww reactions
MESSAGE_REACTION_REMOVE: 'MESSAGE_REACTION_REMOVE', // ^^
MESSAGE_REACTION_REMOVE_ALL: 'MESSAGE_REACTION_REMOVE_ALL', // ^^
CHANNEL_PINS_ACK: 'CHANNEL_PINS_ACK', // Pinned messages fetch
CHANNEL_PINS_UPDATE: 'CHANNEL_PINS_UPDATE', // Message pinned/unpinned, does not trigger when message is deleted
CHANNEL_CREATE: 'CHANNEL_CREATE', // Channel created
CHANNEL_DELETE: 'CHANNEL_DELETE', // Channel deleted
CHANNEL_UPDATE: 'CHANNEL_UPDATE', // Channel updated
GUILD_CREATE: 'GUILD_CREATE', // Guild create
GUILD_DELETE: 'GUILD_DELETE', // Guild delete
GUILD_SYNC: 'GUILD_SYNC', // Synced when switching to server that's not loaded
GUILD_MEMBERS_CHUNK: 'GUILD_MEMBERS_CHUNK', // ??
GUILD_BAN_ADD: 'GUILD_BAN_ADD', // User banned
GUILD_BAN_REMOVE: 'GUILD_BAN_REMOVE', // User unbanned
GUILD_MEMBER_ADD: 'GUILD_MEMBER_ADD', // User joins guild
GUILD_MEMBER_UPDATE: 'GUILD_MEMBER_UPDATE', // Roles etc
GUILD_MEMBER_REMOVE: 'GUILD_MEMBER_REMOVE', // Kick
GUILD_ROLE_CREATE: 'GUILD_ROLE_CREATE', // Roles
GUILD_ROLE_UPDATE: 'GUILD_ROLE_UPDATE', // Roles
GUILD_ROLE_DELETE: 'GUILD_ROLE_DELETE', // Roles,
GUILD_EMOJIS_UPDATE: 'GUILD_EMOJIS_UPDATE', // No emojis pls
GUILD_INTEGRATIONS_UPDATE: 'GUILD_INTEGRATIONS_UPDATE', // Twitch etc?
USER_UPDATE: 'USER_UPDATE', // Name change etc?
USER_SETTINGS_UPDATE: 'USER_SETTINGS_UPDATE', // Any setting change
USER_GUILD_SETTINGS_UPDATE: 'USER_GUILD_SETTINGS_UPDATE', // Guild notification/privacy etc
USER_CONNECTIONS_UPDATE: 'USER_CONNECTIONS_UPDATE', // Steam etc
USER_REQUIRED_ACTION_UPDATE: 'USER_REQUIRED_ACTION_UPDATE', // ??
USER_NOTE_UPDATE: 'USER_NOTE_UPDATE', // Not edits
RELATIONSHIP_ADD: 'RELATIONSHIP_ADD', // Friends
RELATIONSHIP_REMOVE: 'RELATIONSHIP_REMOVE', // Friends
PRESENCE_UPDATE: 'PRESENCE_UPDATE', // Status
PRESENCES_REPLACE: 'PRESENCES_REPLACE', // ??
VOICE_STATE_UPDATE: 'VOICE_STATE_UPDATE', // Speaking?
VOICE_SERVER_UPDATE: 'VOICE_SERVER_UPDATE', // ??
CALL_CREATE: 'CALL_CREATE', // Don't call me
CALL_UPDATE: 'CALL_UPDATE', // ^^^^^^^^^^^^
CALL_DELETE: 'CALL_DELETE', // ^^^^^^^^^^^^
OAUTH2_TOKEN_REVOKE: 'OAUTH2_TOKEN_REVOKE', // Logged out elsewhere?
RECENT_MENTION_DELETE: 'RECENT_MENTION_DELETE', // No idea what triggers this?
FRIEND_SUGGESTION_CREATE: 'FRIEND_SUGGESTION_CREATE', // Connected account stuff?
FRIEND_SUGGESTION_DELETE: 'FRIEND_SUGGESTION_DELETE', // ^^
WEBHOOKS_UPDATE: 'WEBHOOKS_UPDATE', // Any webhook change on any server
USER_PAYMENTS_UPDATE: 'USER_PAYMENTS_UPDATE', // Won't test
USER_BILLING_PROFILE_UPDATE: 'USER_BILLING_PROFILE_UPDATE', // Won't test
ACTIVITY_JOIN_REQUEST: 'ACTIVITY_JOIN_REQUEST', // Nothing seems to trigger this
ACTIVITY_JOIN_INVITE: 'ACTIVITY_JOIN_INVITE', // Same
LFG_LISTING_CREATE: 'LFG_LISTING_CREATE', // No groups here
LFG_LISTING_DELETE: 'LFG_LISTING_DELETE', // Thank you
BRAINTREE_POPUP_BRIDGE_CALLBACK: 'BRAINTREE_POPUP_BRIDGE_CALLBACK' // What
}
}
}

View File

@ -37,16 +37,16 @@ export default new class extends Module {
}; };
window.jQuery = {}; window.jQuery = {};
Events.emit('global-ready');
})();
if (window.__bd) { if (window.__bd) {
this.setState(window.__bd); this.setState(window.__bd);
window.__bd = { window.__bd = {
setWS: this.setWS setWS: this.setWS
} }
Events.emit('socket-created', this.state.wsHook);
} }
Events.emit('global-ready');
Events.emit('socket-created', this.state.wsHook);
})();
} }
setWS(wSocket) { setWS(wSocket) {

View File

@ -10,18 +10,20 @@
/*Module Manager initializes all modules when everything is ready*/ /*Module Manager initializes all modules when everything is ready*/
import { Events } from 'modules'; import { Events, SocketProxy, EventHook } from 'modules';
import { ProfileBadges } from 'ui'; import { ProfileBadges } from 'ui';
export default class { export default class {
static get modules() { static get modules() {
return this._modules ? this._modules : (this._modules = [ return this._modules ? this._modules : (this._modules = [
new ProfileBadges() new ProfileBadges(),
new SocketProxy(),
new EventHook()
]); ]);
} }
static initModules() { static async initModules() {
for (let module of this.modules) { for (let module of this.modules) {
try { try {
if (module.init && module.init instanceof Function) module.init(); if (module.init && module.init instanceof Function) module.init();
@ -29,6 +31,7 @@ export default class {
console.log(`Failed to initialize module: ${err}`); console.log(`Failed to initialize module: ${err}`);
} }
} }
return true;
} }
} }

View File

@ -8,3 +8,5 @@ export { default as Vendor } from './vendor';
export { default as WebpackModules } from './webpackmodules'; export { default as WebpackModules } from './webpackmodules';
export { default as ModuleManager } from './modulemanager'; export { default as ModuleManager } from './modulemanager';
export { default as EventListener } from './eventlistener'; export { default as EventListener } from './eventlistener';
export { default as SocketProxy } from './socketproxy';
export { default as EventHook } from './eventhook';

View File

@ -0,0 +1,39 @@
/**
* BetterDiscord Discord Socket Proxy Module
* Copyright (c) 2015-present Jiiks/JsSucks - https://github.com/Jiiks / https://github.com/JsSucks
* All rights reserved.
* https://betterdiscord.net
*
* This source code is licensed under the MIT license found in the
* LICENSE file in the root directory of this source tree.
*/
import EventListener from './eventlistener';
export default class SocketProxy extends EventListener {
bindings() {
this.socketCreated = this.socketCreated.bind(this);
this.onMessage = this.onMessage.bind(this);
}
get eventBindings() {
return [
{ id: 'socket-created', 'callback': this.socketCreated }
];
}
get socket() {
return this.activeSocket;
}
socketCreated(socket) {
this.activeSocket = socket;
// socket.addEventListener('message', this.onMessage);
}
onMessage(e) {
console.info(e);
}
}

View File

@ -10,6 +10,7 @@
import WebpackModules from './webpackmodules'; import WebpackModules from './webpackmodules';
import jQuery from 'jquery'; import jQuery from 'jquery';
import lodash from 'lodash';
export default class { export default class {
@ -21,6 +22,14 @@ export default class {
return this.jQuery; return this.jQuery;
} }
static get lodash() {
return lodash;
}
static get _() {
return this.lodash;
}
static get moment() { static get moment() {
return WebpackModules.getModuleByName('Moment'); return WebpackModules.getModuleByName('Moment');
} }

View File

@ -0,0 +1,4 @@
export * from './socketstructs/channel';
export * from './socketstructs/generic';
export * from './socketstructs/guild';
export * from './socketstructs/message';

View File

@ -0,0 +1,28 @@
/**
* BetterDiscord Channel Event Structs
* Copyright (c) 2015-present Jiiks/JsSucks - https://github.com/Jiiks / https://github.com/JsSucks
* All rights reserved.
* https://betterdiscord.net
*
* This source code is licensed under the MIT license found in the
* LICENSE file in the root directory of this source tree.
*/
import DiscordEvent from './discordevent';
export class CHANNEL_PINS_UPDATE extends DiscordEvent {
get channelId() { return this.args.channelId }
get lastPinTimestamp() { return this.args.lastPinTimestamp }
}
// TODO
export class CHANNEL_CREATE extends DiscordEvent {}
export class CHANNEL_DELETE extends DiscordEvent {}
export class CHANNEL_UPDATE extends DiscordEvent {}
export class CHANNEL_PINS_ACK {
get channelId() { return this.args.channelId }
get timestamp() { return this.args.timestamp }
}

View File

@ -0,0 +1,18 @@
/**
* BetterDiscord Discord Event Base
* Copyright (c) 2015-present Jiiks/JsSucks - https://github.com/Jiiks / https://github.com/JsSucks
* All rights reserved.
* https://betterdiscord.net
*
* This source code is licensed under the MIT license found in the
* LICENSE file in the root directory of this source tree.
*/
import { Utils } from 'common';
export default class DiscordEvent {
constructor(args) {
this.args = Utils.toCamelCase(args);
Object.freeze(this.args);
}
}

View File

@ -0,0 +1,49 @@
/**
* BetterDiscord Generic Event Structs
* Copyright (c) 2015-present Jiiks/JsSucks - https://github.com/Jiiks / https://github.com/JsSucks
* All rights reserved.
* https://betterdiscord.net
*
* This source code is licensed under the MIT license found in the
* LICENSE file in the root directory of this source tree.
*/
import DiscordEvent from './discordevent';
export class TYPING_START extends DiscordEvent {
get channelId() { return this.args.channelId }
get userId() { return this.args.userId }
}
export class PRESENCE_UPDATE extends DiscordEvent {
get game() { return this.args.game }
get guildId() { return this.args.guildId }
get nick() { return this.args.nick }
get roles() { return this.args.roles }
get status() { return this.args.status }
get user() { return this.args.user }
get lastModified() { return this.args.lastModified }
}
export class VOICE_STATE_UPDATE extends DiscordEvent {
get channelId() { return this.args.channelId }
get deaf() { return this.args.deaf }
get guildId() { return this.args.guildId }
get mute() { return this.args.mute }
get selfDeaf() { return this.args.selfDeaf }
get selfMute() { return this.args.selfMute }
get selfVideo() { return this.args.selfVideo }
get sessionId() { return this.args.sessionId }
get suppress() { return this.args.suppress }
get userId() { return this.args.userId }
}
// Doesn't have everything
export class USER_SETTINGS_UPDATE extends DiscordEvent {
get status() { return this.args.status }
get messageDisplayCompact() { return this.args.messageDisplayCompact }
get theme() { return this.args.theme }
}
export class USER_GUILD_SETTINGS_UPDATE extends DiscordEvent { }
export class ACTIVITY_START extends DiscordEvent {}

View File

@ -0,0 +1,83 @@
/**
* BetterDiscord Guild Event Structs
* Copyright (c) 2015-present Jiiks/JsSucks - https://github.com/Jiiks / https://github.com/JsSucks
* All rights reserved.
* https://betterdiscord.net
*
* This source code is licensed under the MIT license found in the
* LICENSE file in the root directory of this source tree.
*/
import DiscordEvent from './discordevent';
export class GUILD_CREATE extends DiscordEvent {
get afkChannelId() { return this.args.afkChannelId }
get afkTimeout() { return this.args.afkTimeout }
get applicationId() { return this.args.applicationId }
get defaultMessageNotifications() { return this.args.defaultMessageNotifications }
get emojis() { return this.args.emojis }
get explicitContentFilter() { return this.args.explicitContentFilter }
get features() { return this.args.features }
get icon() { return this.args.icon }
get id() { return this.args.id }
get joinedAt() { return this.args.joinedAt }
get large() { return this.args.large }
get memberCount() { return this.args.memberCount }
get mfaLevel() { return this.args.mfaLevel }
get name() { return this.args.name }
get ownerId() { return this.args.ownerId }
get presences() { return this.args.presences }
get region() { return this.args.region }
get roles() { return this.args.roles }
get splash() { return this.args.splash }
get systemChannelId() { return this.args.systemChannelId }
get unavailable() { return this.args.unavailable }
get verificationLevel() { return this.args.verificationLevel }
get voiceStates() { return this.args.voiceStates }
get channels() { return this.args.channels }
get members() { return this.args.members }
}
export class GUILD_DELETE extends DiscordEvent {
get id() { return this.args.id }
get unavailable() { return this.args.unavailable }
}
export class GUILD_SYNC extends DiscordEvent {
get id() { return this.args.id }
get large() { return this.args.large }
get members() { return this.args.members }
get presences() { return this.args.presences }
}
export class GUILD_MEMBERS_CHUNK extends DiscordEvent {}
export class GUILD_BAN_ADD extends DiscordEvent {}
export class GUILD_BAN_REMOVE extends DiscordEvent {}
export class GUILD_MEMBER_ADD extends DiscordEvent {
get guildId() { return this.args.guildId }
get joinedAt() { return this.args.joinedAt }
get mute() { return this.args.mute }
get deaf() { return this.args.deaf }
get roles() { return this.args.roles }
get user() { return this.args.user }
}
export class GUILD_MEMBER_UPDATE extends DiscordEvent {}
export class GUILD_MEMBER_REMOVE extends DiscordEvent {
get guildId() { return this.args.guildId }
get user() { return this.args.user }
}
export class GUILD_ROLE_CREATE extends DiscordEvent {}
export class GUILD_ROLE_UPDATE extends DiscordEvent {}
export class GUILD_ROLE_DELETE extends DiscordEvent {}
export class GUILD_EMOJIS_UPDATE extends DiscordEvent {}
export class GUILD_INTEGRATIONS_UPDATE extends DiscordEvent {}

View File

@ -0,0 +1,51 @@
/**
* BetterDiscord Message Event Structs
* Copyright (c) 2015-present Jiiks/JsSucks - https://github.com/Jiiks / https://github.com/JsSucks
* All rights reserved.
* https://betterdiscord.net
*
* This source code is licensed under the MIT license found in the
* LICENSE file in the root directory of this source tree.
*/
import DiscordEvent from './discordevent';
export class MESSAGE_CREATE extends DiscordEvent {
get author() { return this.args.author }
get channelId() { return this.args.channelId }
get content() { return this.args.content }
get attachments() { return this.args.attachments }
get editedTimestamp() { return this.args.editedTimestamp }
get embeds() { return this.args.embeds }
get id() { return this.args.id }
get mentionEveryone() { return this.args.mentionEveryone }
get mentionRoles() { return this.args.mentionRoles }
get mentions() { return this.args.mentions }
get nonce() { return this.args.nonce }
get pinned() { return this.args.pinned }
get timestamp() { return this.args.timestamp }
get tts() { return this.args.tts }
get type() { return this.args.type }
}
export class MESSAGE_UPDATE extends MESSAGE_CREATE { }
export class MESSAGE_DELETE extends DiscordEvent {
get channelId() { return this.args.channelId }
get messageId() { return this.args.messageId }
}
// TODO
export class MESSAGE_DELETE_BULK extends DiscordEvent {}
export class MESSAGE_ACK extends DiscordEvent {
get channelId() { return this.args.channelId }
get messageId() { return this.args.messageId }
}
export class MESSAGE_REACTION_ADD extends DiscordEvent {
get channelId() { return this.args.channelId }
get messageId() { return this.args.messageId }
get userId() { return this.args.userId }
get emoji() { return this.args.emoji }
}
export class MESSAGE_REACTION_REMOVE extends MESSAGE_REACTION_ADD { }

View File

@ -10,7 +10,8 @@
const const
path = require('path'), path = require('path'),
fs = require('fs'); fs = require('fs'),
_ = require('lodash');
import { Vendor } from 'modules'; import { Vendor } from 'modules';
@ -33,6 +34,17 @@ export class Utils {
}); });
} }
} }
static toCamelCase(o) {
const camelCased = {};
_.forEach(o, (value, key) => {
if (_.isPlainObject(value) || _.isArray(value)) {
value = this.toCamelCase(value);
}
camelCased[_.camelCase(key)] = value;
});
return camelCased;
}
} }
export class FileUtils { export class FileUtils {

View File

@ -31,6 +31,7 @@
"gulp-plumber": "^1.2.0", "gulp-plumber": "^1.2.0",
"gulp-watch": "^5.0.0", "gulp-watch": "^5.0.0",
"jquery": "^3.2.1", "jquery": "^3.2.1",
"lodash": "^4.17.4",
"node-sass": "^4.7.2", "node-sass": "^4.7.2",
"pump": "^2.0.0", "pump": "^2.0.0",
"sass-loader": "^6.0.6", "sass-loader": "^6.0.6",