blaster is now working

This commit is contained in:
2025-04-02 22:12:18 +02:00
parent 50750508ab
commit 92d5c53376
4 changed files with 49 additions and 4 deletions

View File

@@ -1,7 +1,9 @@
import { HelixUser } from "@twurple/api"
import { getInventory, updateInventory } from "../lib/userHelper"
import { getInventory, updateInventory, changeBalance } from "../lib/userHelper"
import { timeout, addTimeoutToDB } from "./timeoutHelper"
import api from "./api"
const ITEMS = ['blaster', 'silverbullet', 'grenade', 'tnt', 'watergun', 'clipboard', 'lootbox']
export const ITEMS = ['blaster', 'silverbullet', 'grenade', 'tnt', 'watergun', 'clipboard', 'lootbox']
interface itemChangeResult {
result: boolean,
@@ -22,3 +24,27 @@ export async function changeItemCount(user: HelixUser, item: string, amount = -1
await updateInventory(user, inv)
return { result: true, reason: '', count: inv[item] }
}
export async function useBlaster(broadcasterId: string, attacker: HelixUser, targetname: string, say: (arg0: string) => Promise<void>) {
const target = await api.users.getUserByName(targetname)
const result = await timeout(broadcasterId, target!, 60, `You got blasted by ${attacker.name}`)
if (result.status) {
const itemResult = await changeItemCount(attacker, 'blaster')
await say(`${targetname} got mandoooGun by ${attacker.name}! mandoooGOTTEM ${attacker.name} has ${itemResult.count} blaster${itemResult.count === 1 ? '' : 's'} remaining`)
await addTimeoutToDB(attacker, target!, 'blaster')
} else {
switch (result.reason) {
case 'noexist':
await say(`${targetname} doesn't exist!`)
break
case 'banned':
await say(`${targetname} is already dead!`)
break
case 'unknown':
await say(`NO!`)
await timeout(broadcasterId, attacker, 60, "NO!")
break
}
}
}