mirror of
https://github.com/qwerinope/qweribot.git
synced 2025-12-19 05:51:37 +01:00
add silverbullet cheer, add timeout command
This commit is contained in:
@@ -54,6 +54,7 @@ COMMAND|FUNCTION|USER|ALIASES|DISABLEABLE
|
|||||||
`ping`|Testing command|anyone|`ping`|:white_check_mark:
|
`ping`|Testing command|anyone|`ping`|:white_check_mark:
|
||||||
`yabai`|Random number|anyone|`yabai` `goon`|:white_check_mark:
|
`yabai`|Random number|anyone|`yabai` `goon`|:white_check_mark:
|
||||||
`seiso`|Random number|anyone|`seiso`|:white_check_mark:
|
`seiso`|Random number|anyone|`seiso`|:white_check_mark:
|
||||||
|
`timeout {target}`|Times targeted user out for 60 seconds (costs 100 qweribucks)|anyone|`timeout`|:white_check_mark:
|
||||||
|
|
||||||
### Qweribucks commands
|
### Qweribucks commands
|
||||||
|
|
||||||
@@ -104,4 +105,5 @@ TNT|`tnt`|Give 5-10 random chatters 60 second timeouts|`tnt`
|
|||||||
|
|
||||||
NAME|AMOUNT|USAGE|FUNCTION
|
NAME|AMOUNT|USAGE|FUNCTION
|
||||||
-|-|-|-
|
-|-|-|-
|
||||||
`timeout`|100|`cheer100 {target}`|Times specified user out for 1 minute
|
`timeout`|100|`cheer100 {target}`|Times specified user out for 1 minute. On failure gives cheerer a blaster
|
||||||
|
`execute`|6666|`cheer6666 {target}`|Times specified user out for 24 hours. On failure gives cheerer a silver bullet
|
||||||
|
|||||||
54
src/cheers/execute.ts
Normal file
54
src/cheers/execute.ts
Normal file
@@ -0,0 +1,54 @@
|
|||||||
|
import { Cheer } from ".";
|
||||||
|
import { EventSubChannelChatMessageEvent } from "@twurple/eventsub-base"
|
||||||
|
import { changeItemCount } from "../items";
|
||||||
|
import { sendMessage } from "../commands";
|
||||||
|
import { getUserRecord } from "../db/dbUser";
|
||||||
|
import { User } from "../user";
|
||||||
|
import { timeout } from "../lib/timeout";
|
||||||
|
import { createTimeoutRecord } from "../db/dbTimeouts";
|
||||||
|
import logger from "../lib/logger";
|
||||||
|
import { parseCheerArgs } from "../lib/parseCommandArgs";
|
||||||
|
|
||||||
|
export default new Cheer('execute', 6666, async (msg, user) => {
|
||||||
|
const args = parseCheerArgs(msg.messageText);
|
||||||
|
if (!args[0]) { await handleNoExecuteTarget(msg, user, false); return; };
|
||||||
|
const target = await User.initUsername(args[0].toLowerCase());
|
||||||
|
if (!target) { await handleNoExecuteTarget(msg, user, false); return; };
|
||||||
|
await getUserRecord(target);
|
||||||
|
|
||||||
|
const result = await timeout(target, `You got executed by ${user.displayName}!`, 60 * 60 * 24);
|
||||||
|
if (result.status) await Promise.all([
|
||||||
|
sendMessage(`${target.displayName} RIPBOZO RIPBOZO RIPBOZO RIPBOZO RIPBOZO RIPBOZO RIPBOZO`),
|
||||||
|
createTimeoutRecord(user, target, 'silverbullet'),
|
||||||
|
]);
|
||||||
|
else {
|
||||||
|
await handleNoExecuteTarget(msg, user);
|
||||||
|
switch (result.reason) {
|
||||||
|
case "banned":
|
||||||
|
await sendMessage(`${target.displayName} is already timed out/banned`, msg.messageId);
|
||||||
|
break;
|
||||||
|
case "illegal":
|
||||||
|
await Promise.all([
|
||||||
|
sendMessage(`${user.displayName} Nou Nou Nou`),
|
||||||
|
timeout(user, 'nah', 60)
|
||||||
|
]);
|
||||||
|
break;
|
||||||
|
case "unknown":
|
||||||
|
await sendMessage('Something went wrong...', msg.messageId);
|
||||||
|
break;
|
||||||
|
};
|
||||||
|
};
|
||||||
|
});
|
||||||
|
|
||||||
|
async function handleNoExecuteTarget(msg: EventSubChannelChatMessageEvent, user: User, silent = true) {
|
||||||
|
if (await user.itemLock()) {
|
||||||
|
await sendMessage(`Cannot give ${user.displayName} a silver bullet`, msg.messageId);
|
||||||
|
logger.err(`Failed to give ${user.displayName} a silver bullet for their cheer`);
|
||||||
|
return;
|
||||||
|
};
|
||||||
|
await user.setLock();
|
||||||
|
const userRecord = await getUserRecord(user);
|
||||||
|
if (!silent) await sendMessage('No (valid) target specified. You got a silver bullet!', msg.messageId);
|
||||||
|
await changeItemCount(user, userRecord, 'silverbullet', 1);
|
||||||
|
await user.clearLock();
|
||||||
|
};
|
||||||
41
src/commands/timeout.ts
Normal file
41
src/commands/timeout.ts
Normal file
@@ -0,0 +1,41 @@
|
|||||||
|
import { Command, sendMessage } from ".";
|
||||||
|
import { getUserRecord } from "../db/dbUser";
|
||||||
|
import parseCommandArgs from "../lib/parseCommandArgs";
|
||||||
|
import { User } from "../user";
|
||||||
|
import { timeout } from "../lib/timeout";
|
||||||
|
import { changeBalance } from "../lib/changeBalance";
|
||||||
|
import { createTimeoutRecord } from "../db/dbTimeouts";
|
||||||
|
|
||||||
|
export default new Command('timeout', ['timeout'], 'chatter', async (msg, user) => {
|
||||||
|
const userObj = await getUserRecord(user);
|
||||||
|
if (userObj.balance < 100) { await sendMessage(`You don't have enough qweribucks (need 100, have ${userObj.balance})`, msg.messageId); return; };
|
||||||
|
const messagequery = parseCommandArgs(msg.messageText);
|
||||||
|
if (!messagequery[0]) { await sendMessage('Please specify a target'); return; };
|
||||||
|
const target = await User.initUsername(messagequery[0].toLowerCase());
|
||||||
|
if (!target) { await sendMessage(`${messagequery[0]} doesn't exist`); return; };
|
||||||
|
await getUserRecord(target); // make sure the user record exist in the database
|
||||||
|
|
||||||
|
const result = await timeout(target, `You got BLASTED by ${user.displayName}`, 60);
|
||||||
|
if (result.status) {
|
||||||
|
await Promise.all([
|
||||||
|
sendMessage(`GOTTEM ${target.displayName} got BLASTED by ${user.displayName} GOTTEM`),
|
||||||
|
changeBalance(user, userObj, -100),
|
||||||
|
createTimeoutRecord(user, target, 'blaster')
|
||||||
|
]);
|
||||||
|
} else {
|
||||||
|
switch (result.reason) {
|
||||||
|
case "banned":
|
||||||
|
await sendMessage(`${target.displayName} is already timed out/banned`, msg.messageId);
|
||||||
|
break;
|
||||||
|
case "illegal":
|
||||||
|
await Promise.all([
|
||||||
|
sendMessage(`${user.displayName} Nou Nou Nou`),
|
||||||
|
timeout(user, 'nah', 60)
|
||||||
|
]);
|
||||||
|
break;
|
||||||
|
case "unknown":
|
||||||
|
await sendMessage('Something went wrong...', msg.messageId);
|
||||||
|
break;
|
||||||
|
};
|
||||||
|
};
|
||||||
|
});
|
||||||
Reference in New Issue
Block a user