summary refs log tree commit diff
path: root/src/plugins/example-plugin/TestPlugin.ts
diff options
context:
space:
mode:
authorTheArcaneBrony <myrainbowdash949@gmail.com>2022-08-13 17:16:23 +0200
committerTheArcaneBrony <myrainbowdash949@gmail.com>2022-09-04 10:48:54 +0200
commit8769c7625cafd14e6f304601cc99a195e833d38b (patch)
tree94d37b1ef271490a032cde0605e1b1fb0fe01e0c /src/plugins/example-plugin/TestPlugin.ts
parentPlugins finally load! (diff)
downloadserver-8769c7625cafd14e6f304601cc99a195e833d38b.tar.xz
Fix config table, add plugin events, implement onPreMessageEvent, add
http error data field, migrations
Diffstat (limited to 'src/plugins/example-plugin/TestPlugin.ts')
-rw-r--r--src/plugins/example-plugin/TestPlugin.ts28
1 files changed, 21 insertions, 7 deletions
diff --git a/src/plugins/example-plugin/TestPlugin.ts b/src/plugins/example-plugin/TestPlugin.ts

index 7a86aab2..18e634f7 100644 --- a/src/plugins/example-plugin/TestPlugin.ts +++ b/src/plugins/example-plugin/TestPlugin.ts
@@ -1,12 +1,26 @@ -import { Plugin } from "@fosscord/util"; +import { setupListener } from "@fosscord/gateway"; +import { Channel, Guild, Plugin, PluginLoadedEventArgs, PluginLoader, PluginManifest, PreMessageEventArgs, PreMessageEventResult } from "@fosscord/util"; +import { TestSettings } from "./TestSettings"; export default class TestPlugin implements Plugin { - pluginPath: string; - async initConfig(): Promise<void> { - - } - onPluginLoaded() { + pluginManifest?: PluginManifest | undefined; + settings: TestSettings = new TestSettings(); + async onPluginLoaded(env: PluginLoadedEventArgs) { console.log("Test plugin active!"); + if(this.pluginManifest) this.settings = PluginLoader.getPluginConfig(this.pluginManifest.id, this.settings) as TestSettings; + } + async onPreMessage(data: PreMessageEventArgs): Promise<PreMessageEventResult> { + let channel = await Channel.findOne({ where: { id: data.message.channel_id } }); + let guild = await Guild.findOne({ where: { id: data.message.guild_id } }); + let block = data.message.content?.includes('UwU'); + + let result = {cancel: block} as PreMessageEventResult; + + if(block) { + console.log(`[TestPlugin] Blocked message in ${guild?.name}/#${channel?.name} by ${data.message.author?.username}: ${data.message.content}`); + result.blockReason = "[TestPlugin] Your message contains UwU! Get bamboozled!"; + } + + return result; } - } \ No newline at end of file