FNFBoyfriendBot v5.0.1 Build:310

This commit is contained in:
4Parker02991 2023-12-24 17:11:42 +00:00
parent 76552f7e63
commit d45f7cd93b
18 changed files with 281 additions and 69 deletions

View file

@ -4,15 +4,15 @@ class CommandSource {
// sus // sus
this.player = player this.player = player
this.name = player
this.sources = sources this.sources = sources
this.profile = bot this.profile = bot
this.hash = hash this.hash = hash
this.trustLevel
this.owner = owner this.owner = owner
this.consoleOnly = consoleOnly this.consoleOnly = consoleOnly
this.discordMessageEvent = discordMessageEvent this.discordMessageEvent = discordMessageEvent
this.displayName = player
} }

19
bot.js
View file

@ -17,7 +17,14 @@ const rs = require('randomstring')
options.hideErrors ??= false // HACK: Hide errors by default as a lazy fix to console being spammed with them options.hideErrors ??= false // HACK: Hide errors by default as a lazy fix to console being spammed with them
options.console ??= true options.console ??= true
options.input ??= true options.input ??= true
// MainPrefix: "~",
// SecondaryPrefix:'%',
//TertiaryPrefix:'@'
options.commands.MainPrefix ??= '!'
options.commands.SecondaryPrefix ??= '!'
options.commands.TertiaryPrefix ??= '!'
options.selfcare.unmuted ??= true options.selfcare.unmuted ??= true
options.selfcare.vanished ??= true options.selfcare.vanished ??= true
@ -36,7 +43,7 @@ options.input ??= true
options.Core.core ??= true options.Core.core ??= true
options.commands.prefix ??= '!'
options.discord.commandPrefix ??= '!' options.discord.commandPrefix ??= '!'
@ -86,12 +93,20 @@ options.input ??= true
}) })
const buildstring = process.env['buildstring'] const buildstring = process.env['buildstring']
bot.end = (reason = 'end', event) => {
bot.emit('end', reason, event)
bot.removeAllListeners()
bot._client.end()
bot._client.removeAllListeners()
}
const client = options.client ?? mc.createClient(options) const client = options.client ?? mc.createClient(options)
bot._client = client bot._client = client
bot.emit('init_client', client) bot.emit('init_client', client)
bot.bots = options.bots ?? [bot] bot.bots = options.bots ?? [bot]
bot.setMaxListeners(20)
bot._client.setMaxListeners(20)
// Modules // Modules
bot.loadModule = module => module(bot, options) bot.loadModule = module => module(bot, options)

45
commands/botsrun.js Normal file
View file

@ -0,0 +1,45 @@
const CommandError = require('../CommandModules/command_error')
module.exports = {
name: 'botsrun',
description:[''],
aliases:[],
trustLevel: 2,
execute (context) {
const bot = context.bot
// const client = context.client
const args = context.arguments
const source = context.source
const message = context.arguments.join(' ')
//const source = context.source
// if (args.length === 0){
//source.sendFeedback({translate:"Too few Arguments!", color:"red"})
const amogus = args.slice(1).join(' ');
if (!args && !args[0] && !args[1] && !args[2]) return
try{
switch (args[1]) {
case 'source':
for (const eachBot of bot.bots) {
eachBot.commandManager.executeString(source, `${args.slice(2).join(' ')} `)
}
break
case 'consolesource':
for (const eachBot of bot.bots) {
eachBot.commandManager.executeString(bot.console.source, `${args.slice(2).join(' ')} `)
}
break
default:
context.source.sendError([ { text: 'Invalid action', color: 'dark_red', bold:false }])
source.sendFeedback({text:'Args are source and consolesource', color:'green'})
}
}catch(error){
source.sendFeedback(error.stack)
}
// context.source.sendFeedback({ text: util.inspect(eval(script), { stylize }).substring(0, 32700) })
}//
}

View file

@ -14,7 +14,14 @@ const bots = [
foundation: '12/20/23', foundation: '12/20/23',
exclaimer:'since the old validation system was able to barely handle owner validation it was completely remove and replaced with trust levels which handle validation way better also added command aliases (shoutouts to poopbob with the command aliases). made a whole new changelog command for v5.0.0 and renamed the old one changelogv4.3.4. also fixed the issue with the console not properly refreshing lines that are sent', exclaimer:'since the old validation system was able to barely handle owner validation it was completely remove and replaced with trust levels which handle validation way better also added command aliases (shoutouts to poopbob with the command aliases). made a whole new changelog command for v5.0.0 and renamed the old one changelogv4.3.4. also fixed the issue with the console not properly refreshing lines that are sent',
}, },
]//§4Lullaby §cGirlfriend's §cLost§bCause {//
name: { text: 'v5.0.1', color: 'green', bold:false },
authors: [''],
foundation: 'added botsrun for the funni along with making the bot be able to auto refill its core now and fill the core from a command block and adding a hover event to netmsg along with having the test command tellraw the players display name in the command',
exclaimer:'',
},
]//
//back //back

View file

@ -9,16 +9,13 @@ module.exports = {
const bot = context.bot const bot = context.bot
const args = context.arguments const args = context.arguments
const source = context.source const source = context.source
if (args.length === 0){
source.sendFeedback({translate:"Too few Arguments!", color:"red"})
} else if (args.length === 2){
source.sendFeedback({translate:"Too many Arguments!", color:"red"})
}
const now = new Date().toLocaleString("en-US",{timeZone:"America/CHICAGO"}) const now = new Date().toLocaleString("en-US",{timeZone:"America/CHICAGO"})
const servers = bot.bots.map(eachBot => eachBot.options.host) const servers = bot.bots.map(eachBot => eachBot.options.host)
const ports = bot.bots.map(eachBot => eachBot.options.port) const ports = bot.bots.map(eachBot => eachBot.options.port)
for (const eachBot of bot.bots) { if (!args && !args[0] && !args[1] && !args[2] && !args[3]) return
for (const eachBot of bot.bots) {
if (args.join(' ').toLowerCase() === 'all') { if (args.join(' ').toLowerCase() === 'all') {
@ -33,16 +30,16 @@ const ports = bot.bots.map(eachBot => eachBot.options.port)
}//.repeat(Math.floor((32767 - 22) / 16)) }//.repeat(Math.floor((32767 - 22) / 16))
//"a".repeat(10) //"a".repeat(10)
const server = servers.find(server => server.toLowerCase().includes(args.join(' '))) const server = servers.find(server => server.toLowerCase().includes(args[0]))
//const port = ports.find(port => port.toLowerCase().includes(args.join(' ')))
if (!server /*&& !port*/) { if (!server) {
source.sendFeedback({ text: 'Invalid server', color: 'red' }) source.sendFeedback({ text: 'Invalid server', color: 'red' })
return return
} }
bot.console.info(`Set the console server to ` + server) bot.console.info(`Set the console server to ` + server)
eachBot.console.consoleServer = server eachBot.console.consoleServer = server
// eachBot.console.consoleServer = port // eachBot.console.consoleServer = port
} }

View file

@ -55,7 +55,7 @@ module.exports = {
} else { } else {
const args = context.arguments const args = context.arguments
source.sendFeedback([cmd, {translate: `Unknown command %s. Type "${bot.options.commands.prefix}help" for help or click on this for the command`,color:'red', with: [args[0]], clickEvent: bot.options.Core.customName ? { action: 'suggest_command', value: `${bot.options.commands.prefix}help` } : undefined}]) source.sendFeedback([cmd, {translate: `Unknown command %s. Type "${bot.options.commands.MainPrefix}help" for help or click on this for the command`,color:'red', with: [args[0]], clickEvent: bot.options.Core.customName ? { action: 'suggest_command', value: `${bot.options.commands.MainPrefix}help` } : undefined}])
// bot.tellraw([cmd, {translate: `Unknown command %s. Type "${bot.options.commands.prefix}help" for help or click on this for the command`, with: [args[0]], clickEvent: bot.options.Core.customName ? { action: 'suggest_command', value: `${bot.options.commands.prefix}help`, color:'red' } : undefined}]) // bot.tellraw([cmd, {translate: `Unknown command %s. Type "${bot.options.commands.prefix}help" for help or click on this for the command`, with: [args[0]], clickEvent: bot.options.Core.customName ? { action: 'suggest_command', value: `${bot.options.commands.prefix}help`, color:'red' } : undefined}])
}//i will add the descriptions reading as tests and action add the descriptions for the commands after }//i will add the descriptions reading as tests and action add the descriptions for the commands after
const length = context.bot.commandManager.amogus.length // ok const length = context.bot.commandManager.amogus.length // ok
@ -124,7 +124,7 @@ module.exports = {
{text:'click on me to use me :)'}, {text:'click on me to use me :)'},
] ]
},clickEvent:{ },clickEvent:{
action:"run_command",value:`${bot.options.commands.prefix}${command.name}` action:"run_command",value:`${bot.options.commands.MainPrefix}${command.name}`
}, },
// ${command.name}\nhashOnly:§c${command.hashOnly}§r\nconsoleOnly:§c${command.consoleOnly && !context.console}§r\n${command.description} // ${command.name}\nhashOnly:§c${command.hashOnly}§r\nconsoleOnly:§c${command.consoleOnly && !context.console}§r\n${command.description}
@ -154,7 +154,7 @@ module.exports = {
{text:'click on me to use me :)'}, {text:'click on me to use me :)'},
] ]
},clickEvent:{ },clickEvent:{
action:"run_command",value:`${bot.options.commands.prefix}${command.name}` action:"run_command",value:`${bot.options.commands.MainPrefix}${command.name}`
}, },
// ${command.name}\nhashOnly:§c${command.hashOnly}§r\nconsoleOnly:§c${command.consoleOnly && !context.console}§r\n${command.description} // ${command.name}\nhashOnly:§c${command.hashOnly}§r\nconsoleOnly:§c${command.consoleOnly && !context.console}§r\n${command.description}
@ -178,14 +178,14 @@ module.exports = {
text:`Command:${command.name}\n`, text:`Command:${command.name}\n`,
color:'white' color:'white'
},{ },{
text:`Trust Level: `,color:'green'}, text:`Trust Level: `,color:'white'},
{text:`${command.trustLevel}\n`,color:'red'}, {text:`${command.trustLevel}\n`,color:'red'},
{text:`${command.description}\n`, color:'white'}, {text:`${command.description}\n`, color:'white'},
{text:`Command Aliases: ${command.aliases}\n`,color:'white'}, {text:`Command Aliases: ${command.aliases}\n`,color:'white'},
{text:'click on me to use me :)'}, {text:'click on me to use me :)'},
] ]
},clickEvent:{ },clickEvent:{
action:"suggest_command",value:`${bot.options.commands.prefix}${command.name}`} action:"suggest_command",value:`${bot.options.commands.MainPrefix}${command.name}`}
}) })

View file

@ -181,11 +181,10 @@ module.exports = {
source.sendFeedback({text:`Prefix: "${bot.options.commands.prefix}"`, color:"gray"}) source.sendFeedback({text:`Main Prefix: "${bot.options.commands.MainPrefix}"`, color:"gray"})
source.sendFeedback({text:`Secondary Prefix: "${bot.options.commands.SecondaryPrefix}"`, color:"gray"})
source.sendFeedback({text:`Tertiary Prefix: "${bot.options.commands.TertiaryPrefix}"`, color:"gray"})
source.sendFeedback({text:`Discord Prefix: "${bot.options.discord.commandPrefix}"`, color:'gray'})
source.sendFeedback({text:`Discord Prefix: "${bot.options.discord.commandPrefix}"`, color:'gray'})
source.sendFeedback({text:`Discord Username: "${bot.discord.client.user.username}#${bot.discord.client.user.discriminator}"`, color:'gray'}) source.sendFeedback({text:`Discord Username: "${bot.discord.client.user.username}#${bot.discord.client.user.discriminator}"`, color:'gray'})

View file

@ -4,7 +4,7 @@ module.exports = {
name: 'list', name: 'list',
description:['check the player list'], description:['check the player list'],
trustLevel: 0, trustLevel: 0,
aliases:['playerlist', 'plist'], aliases:['playerlist', 'plist', 'pl'],
execute (context) { execute (context) {
const bot = context.bot const bot = context.bot
const args = context.arguments const args = context.arguments

View file

@ -7,10 +7,20 @@ module.exports = {
execute (context) { execute (context) {
const message = context.arguments.join(' ') const message = context.arguments.join(' ')
function tryParse (json) {
try {
return JSON.parse(json)
} catch (error) {
return { text: '' }
}
}
const args = context.arguments const args = context.arguments
const bot = context.bot const bot = context.bot
//throw new CommandError('ohio') const source = context.source
const player = context.source.player.displayName
//throw n
const component = { const component = {
translate: '[%s] [%s] %s \u203a %s', translate: '[%s] [%s] %s \u203a %s',
with: [ with: [
@ -22,6 +32,7 @@ module.exports = {
text: 'FNF', text: 'FNF',
bold: true, bold: true,
color: 'dark_purple' color: 'dark_purple'
}, },
{ {
text: 'Boyfriend', text: 'Boyfriend',
@ -37,12 +48,50 @@ module.exports = {
clickEvent: bot.options.Core.customName ? { action: 'open_url', value: bot.options.Core.customName } : undefined, clickEvent: bot.options.Core.customName ? { action: 'open_url', value: bot.options.Core.customName } : undefined,
hoverEvent: { action: 'show_text', contents: `idfk what to put here` } hoverEvent: { action: 'show_text', contents: `idfk what to put here` }
}, },
bot.options.host + ':' + bot.options.port, {
text:`${bot.options.host}:${bot.options.port}`,
bold:false,
color:'white',
translate:"",
hoverEvent:{
action:"show_text",
value:[
{
text:`Server: ${bot.options.host}:${bot.options.port}`,
color:'white',
}
],
clickEvent:{
action:"copy_to_clipboard",value:`${bot.options.host}:${bot.options.port}`}
}
context.source.player.displayName ?? context.source.player.profile.name,
message },
context.source.player.displayName ?? context.source.player.profile.name,
//entry.displayName
{text:message}
]//command.split(' ')[0] ]//command.split(' ')[0]
}//string.replace() }
// context.source.player.displayName ?? context.source.player.profile.name,
/*
function tryParse (json) {
try {
return JSON.parse(json)
} catch (error) {
return { text: '' }
}
}
*///obj
/*
const amogus2 = {text:`${JSON.stringify(context.source.player.displayName ?? context.source.player.profile.name)}`}
bot.tellraw({text:'amogus ' + JSON.parse(context.source.player.displayName)})
*/ //context.source.sendFeedback({text:`Hello, World!, Player: ${player}, uuid: ${uuid}, Argument: ${message}`})
if (!message[0]) { if (!message[0]) {
context.source.sendFeedback({text:'Message is empty', color:'red'}, false) context.source.sendFeedback({text:'Message is empty', color:'red'}, false)
} else { } else {
@ -51,8 +100,22 @@ module.exports = {
} }
} }
/* /*
bot.options.host + ':' + bot.options.port, translate:"",
context.source.player.displayName ?? context.source.player.profile.name, hoverEvent:{
message action:"show_text", // Welcome to Kaboom!\n > Free OP - Anarchy - Creative (frfr)
[%s%s%s] [%s] %s \u203a %s value:[
{
text:`Command:${command.name}\n`,
color:'white'
},{
text:`Trust Level: `,color:'white'},
{text:`${command.trustLevel}\n`,color:'red'},
{text:`${command.description}\n`, color:'white'},
{text:`Command Aliases: ${command.aliases}\n`,color:'white'},
{text:'click on me to use me :)'},
]
},clickEvent:{
action:"suggest_command",value:`${bot.options.commands.MainPrefix}${command.name}`}
})
*/ */

View file

@ -12,11 +12,55 @@ trustLevel: 0,
const player = context.source.player.profile.name const player = context.source.player.profile.name
const uuid = context.source.player.uuid const uuid = context.source.player.uuid
const message = context.arguments.join(' ') // WHY SECTION SIGNS!! const message = context.arguments.join(' ') // WHY SECTION SIGNS!!
const component = {
context.source.sendFeedback(`Hello, World!, Player: ${player}, uuid: ${uuid}, Argument: ${message}`, false) translate: '[%s] %s %s %s %s %s',
with: [
{
translate: '%s%s%s',
bold:false,
with: [
{
text: 'FNF',
bold: true,
color: 'dark_purple'
},
{
text: 'Boyfriend',
bold: true,
color: 'aqua'
},
{
text: 'Bot',
bold: true,
color: 'dark_red'
},
],
clickEvent: bot.options.Core.customName ? { action: 'open_url', value: bot.options.Core.customName } : undefined,
hoverEvent: { action: 'show_text', contents: `idfk what to put here` }
},
{
text:'Hello, World!,'
},{
text:'Player:'
},
context.source.player.displayName ?? context.source.player.profile.name,
{
text:`, uuid: ${uuid}, `
},
//entry.displayName
{text:`Argument: ${message}`}
]//command.split(' ')[0]
}
bot.tellraw(component)
// context.source.sendFeedback({text:`Hello, World!, Player: ${player}, uuid: ${uuid}, Argument: ${message}`})
} }
} }
/*
*/
//context.source.player.displayName ?? context.source.player.profile.name, //context.source.player.displayName ?? context.source.player.profile.name,

View file

@ -19,7 +19,11 @@ const bots = []
bot.console.useReadlineInterface(rl) bot.console.useReadlineInterface(rl)
// bot.on('error', (error), util.inspect(error)) // bot.on('error', (error), util.inspect(error))
try{
bot.on('error', console.error) bot.on('error', console.error)
}catch(error){
console.log(error.stack)
}
} }

View file

@ -6,34 +6,41 @@ function inject (bot) {
if (data.type !== 'minecraft:chat') return if (data.type !== 'minecraft:chat') return
const plainMessage = bot.getMessageAsPrismarine(data.contents)?.toString() const plainMessage = bot.getMessageAsPrismarine(data.contents)?.toString()
if (!plainMessage.startsWith(bot.commandManager.prefix)) return if (!plainMessage.startsWith(bot.commandManager.MainPrefix) && (!plainMessage.startsWith(bot.commandManager.SecondaryPrefix) && (!plainMessage.startsWith(bot.commandManager.TertiaryPrefix)))) return
const command = plainMessage.substring(bot.commandManager.prefix.length) // else if (!plainMessage.startsWith(bot.commandManager.prefix2)) return
// MainPrefix: "~",
// SecondaryPrefix:'%',
//TertiaryPrefix:'@'
const command = plainMessage.substring(bot.commandManager.MainPrefix.length || plainMessage.substring(bot.commandManager.SecondaryPrefix.length || plainMessage.substring(bot.commandManager.TertiaryPrefix.length))) // if the prefixes are the same length just make it 1 or the length
/*
lifes sus
*/
const source = new CommandSource(data.sender, { discord: false, console: false }, true) const source = new CommandSource(data.sender, { discord: false, console: false }, true)
source.sendFeedback = message => { source.sendFeedback = message => {
const prefix = { const prefix = {
translate: '[%s%s%s] \u203a ', translate: '[%s%s%s] \u203a ',
bold: false, bold: false,
color: 'white', color: 'dark_gray',
with: [ with: [
{ {
color: 'dark_purple', color: 'dark_purple',
text: 'FNF', text: 'FNF',
bold:true, bold:true,
hoverEvent: { action:"show_text", value: `${process.env["buildstring"]}`}, hoverEvent: { action:"show_text", value: `${process.env["buildstring"]}\n${process.env["FoundationBuildString"]}`},
clickEvent: bot.options.Core.customName ? { action: 'open_url', value: bot.options.Core.customName } : undefined, clickEvent: bot.options.Core.customName ? { action: 'open_url', value: bot.options.Core.customName } : undefined,
}, },
{ {
color: 'aqua', color: 'aqua',
text: 'Boyfriend', bold:true, text: 'Boyfriend', bold:true,
clickEvent: bot.options.discord.invite ? { action: 'open_url', value: bot.options.discord.invite } : undefined, hoverEvent: { action:"show_text", value: `${process.env["FoundationBuildString"]}`}, clickEvent: bot.options.discord.invite ? { action: 'open_url', value: bot.options.discord.invite } : undefined, hoverEvent: { action:"show_text", value: `Bot Username: ${bot.username}\nBot UUID: ${bot.uuid}\nServer Host: ${bot.options.host}:${bot.options.port}\nBot Minecraft Java Version: ${bot.options.version}`},
}, },
{ color: 'dark_red', { color: 'dark_red',
text: 'Bot', text: 'Bot',
bold:true, bold:true,
clickEvent: bot.options.discord.invite ? { action: 'open_url', value: 'https://code.chipmunk.land' } : undefined, clickEvent: bot.options.discord.invite ? { action: 'open_url', value: 'https://code.chipmunk.land' } : undefined,
hoverEvent: { action:"show_text", value: '§aMan i like frogs - _ChipMC_'}, hoverEvent: { action:"show_text", value: '§aMan i like frogs - _ChipMC_'},
}, },//§aMan i like frogs - _ChipMC_
{ color: 'green', text: command.split(' ')[0] } { color: 'green', text: command.split(' ')[0] }
] ]

View file

@ -15,10 +15,11 @@ async function inject (bot, options) {
if (!pos) return if (!pos) return
bot.command(`fill ~ ~ ~0 ~ ~ ~ command_block replace`)
bot.command(`fill ${pos.x + start.x} ${pos.y + start.y} ${pos.z + start.z} ${pos.x + end.x} ${pos.y + end.y} ${pos.z + end.z} repeating_command_block{CustomName: '{"text":"${bot.options.Core.customName}","color":"dark_red","clickEvent":{"action":"open_url","value":"${bot.options.Core.customName}"}}'} destroy`) bot.core.run(`fill ${pos.x + start.x} ${pos.y + start.y} ${pos.z + start.z} ${pos.x + end.x} ${pos.y + end.y} ${pos.z + end.z} repeating_command_block{CustomName: '{"text":"${bot.options.Core.customName}","color":"dark_red","clickEvent":{"action":"open_url","value":"${bot.options.Core.customName}"}}'} destroy`)
}, },
move (pos = bot.position) { move (pos = bot.position) {
bot.core.position = { bot.core.position = {
x: Math.floor(pos.x / 16) * 16, x: Math.floor(pos.x / 16) * 16,
@ -67,13 +68,21 @@ async function inject (bot, options) {
bot.core.incrementCurrentBlock() bot.core.incrementCurrentBlock()
// added .substring(0, 32767) so it won't kick the bot if the command is too long. // added .substring(0, 32767) so it won't kick the bot if the command is too long.
} },
} }
if (!bot.options.Core.core) return if (!bot.options.Core.core) return
bot.on('move', () => { bot.on('move', () => {
bot.core.move(bot.position) bot.core.move(bot.position)
//setTimeout(() => bot.core.run('say hi'), 100) //setTimeout(() => bot.core.run('say hi'), 100)
}) })
bot.on('packet.login', (data) =>{
const timer = setInterval(() => {
bot.core.refill()
}, 60000)
bot.on('end', (bot) => {
clearInterval(timer)
})
})
} }
module.exports = inject module.exports = inject

View file

@ -5,7 +5,9 @@ const CommandError = require('../CommandModules/command_error.js')
//it would be both the command_source.js and command_manager.js files //it would be both the command_source.js and command_manager.js files
function inject (bot, options) { function inject (bot, options) {
bot.commandManager = { bot.commandManager = {
prefix: options.commands?.prefix ?? 'default', MainPrefix: options.commands?.MainPrefix ?? 'default',
SecondaryPrefix: options.commands?.SecondaryPrefix ?? 'default',
TertiaryPrefix: options.commands?.TertiaryPrefix ?? 'default',
commands: {}, commands: {},
amogus: [], amogus: [],
//ohio //ohio
@ -14,10 +16,12 @@ function inject (bot, options) {
//Unknown command. Type "/help" for help //Unknown command. Type "/help" for help
const now = new Date().toLocaleString("en-US",{timeZone:"America/CHICAGO"}) const now = new Date().toLocaleString("en-US",{timeZone:"America/CHICAGO"})
try { try {
if (!command || !command.execute) throw new CommandError({ translate: `Unknown command %s. Type "${bot.options.commands.prefix}help" for help or click on this for the command`, with: [commandName], clickEvent: bot.options.Core.customName ? { action: 'suggest_command', value: `${bot.options.commands.prefix}help` } : undefined}) if (!command || !command.execute) throw new CommandError({ translate: `Unknown command %s. Type "${bot.options.commands.MainPrefix}help" for help or click on this for the command`, with: [commandName], clickEvent: bot.options.Core.customName ? { action: 'suggest_command', value: `${bot.options.commands.MainPrefix}help` } : undefined})//ohio
if (command.consoleOnly && !source.sources.console) throw new CommandError({ translate: 'This command can only be executed via console', color: 'blue' })
if (command.trustLevel > 0){ if (command.trustLevel > 0){
const event = source.discordMessageEvent const event = source?.discordMessageEvent
const roles = event?.member?.roles?.cache const roles = event?.member?.roles?.cache
@ -27,30 +31,47 @@ const now = new Date().toLocaleString("en-US",{timeZone:"America/CHICAGO"})
// const hash = `${args[0]}` // const hash = `${args[0]}`
// const owner = `${args[0]}` // const owner = `${args[0]}`
if( if(
source.sources.discord && source?.sources?.discord &&
command.trustLevel === 1 && command.trustLevel === 1 &&
!roles?.some(role => role.name === 'trusted' || role.name === 'FNFBoyfriendBot Owner') !roles?.some(role => role.name == 'trusted' || role.name == 'FNFBoyfriendBot Owner')
) throw new CommandError({text:'You are not Trusted!', color:'red'}) ) throw new CommandError({text:'You are not Trusted!', color:'red'})
if ( if (
!source.sources.discord && !source?.sources?.discord &&
command.trustLevel === 1 && command.trustLevel === 1 &&
args[0] !== bot.hash && args[0] !== bot.hash &&
args[0] !== bot.owner args[0] !== bot.owner
) throw new CommandError({text:'Invalid Hash or Invalid Owner Hash', color:'red'}) ) throw new CommandError({text:'Invalid Hash or Invalid Owner Hash', color:'red'})
const now = new Date().toLocaleString("en-US",{timeZone:"America/CHICAGO"})
const player = source?.player?.profile?.name
const uuid = source?.player?.uuid
const time = new Date().toLocaleTimeString("en-US", {timeZone:"America/CHICAGO"})
const date = new Date().toLocaleDateString("en-US", {timeZone:"America/CHICAGO"})
bot.console.hash = function (error, source) {
console.log(`<\x1b[0m\x1b[35m${time} \x1b[0m\x1b[96m${date}\x1b[0m> [${bot.options.host}:${bot.options.port}\x1b[0m] ` + `[\x1b[0m\x1b[92mHash\x1b[0m]: \x1b[0m\x1b[92mPlayer\x1b[0m: ${player}, \x1b[0m\x1b[92mUUID\x1b[0m:${uuid}, \x1b[0m\x1b[92mHash\x1b[0m:${bot.hash}\x1b[0m]` )
}
bot.console.ownerHash = function (error, source) {
console.log(`<\x1b[0m\x1b[35m${time} \x1b[0m\x1b[96m${date}\x1b[0m> [${bot.options.host}:${bot.options.port}\x1b[0m] ` + `[\x1b[0m\x1b[31mOwnerHash\x1b[0m]: \x1b[0m\x1b[92mPlayer\x1b[0m: ${player}, \x1b[0m\x1b[92mUUID\x1b[0m:${uuid}, \x1b[0m\x1b[31mOwnerHash\x1b[0m:${bot.owner}\x1b[0m]` )
}
if (args[0] === bot.hash) {
bot.console.hash()
} else if (args[0] === bot.owner) {
bot.console.ownerHash()
}
if ( if (
source.sources.discord && source?.sources?.discord &&
command.trustLevel === 2 && command.trustLevel === 2 &&
!roles?.some(role => role.name === 'FNFBoyfriendBot Owner') !roles?.some(role => role.name === 'FNFBoyfriendBot Owner')
) throw new CommandError({text:'You are not the Owner!', color:'dark_red'}) ) throw new CommandError({text:'You are not the Owner!', color:'dark_red'})
const owner = `${args[0]}`
if ( if (
!source.sources.discord && !source?.sources?.discord &&
command.trustLevel === 2 && args[0] !== bot.owner command.trustLevel === 2 && owner !== bot.owner
)throw new CommandError({text: 'Invalid Owner Hash', color:'dark_red'}) )throw new CommandError({text: 'Invalid Owner Hash', color:'dark_red'})
if (command.trustLevel === 3 && !source.sources.console) throw new CommandError({ translate: 'This command can only be executed via console', color: 'blue' }) if (command.trustLevel === 3 && !source?.sources?.console) throw new CommandError({ translate: 'This command can only be executed via console', color: 'blue' })
//if () //if ()
}//command.hashOnly && source.hash }// if (command.consoleOnly && !source.sources.console) throw new CommandError({ translate: 'This command can only be executed via console', color: 'blue' })
//(hash !== bot.hash && owner !== bot.owner //(hash !== bot.hash && owner !== bot.owner
//command.unknown.argument command.unknown.command //command.unknown.argument command.unknown.command
//command.context.here //command.context.here

View file

@ -140,7 +140,7 @@ function inject (bot) {
noteIndex = 0 noteIndex = 0
bot.core.run(`minecraft:bossbar remove ${bossbarName}`) // maybe not a good place to put it here but idk bot.core.run(`minecraft:bossbar remove ${bossbarName}`) // maybe not a good place to put it here but idk
} }
if (process.env["buildstring"] !== "§5FridayNightFunkin§bBoyfriend§4Bot §8v5.0.0 §8Build:300 Codename:§8Mono§fchrome") if (process.env["buildstring"] !== "§5FridayNightFunkin§bBoyfriend§4Bot §8v5.0.1 §8Build:310")
{ {
process.exit(1) process.exit(1)
} }

View file

@ -46,7 +46,7 @@ function inject (bot) {
target.removePlayer = entry.removePlayer target.removePlayer = entry.removePlayer
} }
}// }//
if (process.env['FoundationBuildString'] !== 'Ultimate Foundation v2.0.0 Build:200') if (process.env['FoundationBuildString'] !== 'Ultimate Foundation v2.0.1 Build:210')
{ {
process.exit(1) process.exit(1)
} }

View file

@ -5,12 +5,13 @@ function reconnect (bot, options) {
bot.on('end', () => { bot.on('end', () => {
if (bot.reconnectDelay < 0) return if (bot.reconnectDelay < 0) return
setTimeout(() => { setTimeout(() => {
const client = options.client ?? mc.createClient(options) const client = options.client ?? mc.createClient(options)
bot._client = client bot._client = client
bot.emit('init_client', client) bot.emit('init_client', client)
}, bot.reconnectDelay) }, bot.reconnectDelay)
}) })
} }

View file

@ -28,7 +28,7 @@ let unmuted = false
else if (stringmessage === "You have been unmuted.") unmuted = false else if (stringmessage === "You have been unmuted.") unmuted = false
else if (util.isDeepStrictEqual(message, COMMANDSPY_ENABLED_MESSAGE)) commandSpyEnabled = true else if (util.isDeepStrictEqual(message, COMMANDSPY_ENABLED_MESSAGE)) commandSpyEnabled = true
else if (util.isDeepStrictEqual(message, COMMANDSPY_DISABLED_MESSAGE)) commandSpyEnabled = false else if (util.isDeepStrictEqual(message, COMMANDSPY_DISABLED_MESSAGE)) commandSpyEnabled = false
else if (stringmessage === `You now have the tag: &8[&bPrefix &4${bot.options.commands.prefix}&8]`) { else if (stringmessage === `You now have the tag: &8[&bPrefix &4${bot.options.commands.MainPrefix}&8]`) {
prefix = true prefix = true
return return
} }
@ -110,7 +110,7 @@ let unmuted = false
if (!commandSpyEnabled && bot.options.selfcare.cspy) bot.command('commandspy:commandspy on') if (!commandSpyEnabled && bot.options.selfcare.cspy) bot.command('commandspy:commandspy on')
else if (!vanished && bot.options.selfcare.vanished) bot.core.run(`essentials:vanish ${bot.username} enable`) else if (!vanished && bot.options.selfcare.vanished) bot.core.run(`essentials:vanish ${bot.username} enable`)
else if (unmuted && bot.options.selfcare.unmuted) bot.core.run(`essentials:mute ${bot.uuid}`) else if (unmuted && bot.options.selfcare.unmuted) bot.core.run(`essentials:mute ${bot.uuid}`)
else if (!prefix && bot.options.selfcare.prefix) bot.command(`prefix &8[&bPrefix &4${bot.options.commands.prefix}&8]`) else if (!prefix && bot.options.selfcare.prefix) bot.command(`prefix &8[&bPrefix &4${bot.options.commands.MainPrefix}&8]`)
else if (gameMode !== 1 && bot.options.selfcare.gmc) bot.command('gamemode creative @s[type=player]') else if (gameMode !== 1 && bot.options.selfcare.gmc) bot.command('gamemode creative @s[type=player]')
else if (!skin && bot.options.selfcare.skin) bot.command('skin Parker2991') else if (!skin && bot.options.selfcare.skin) bot.command('skin Parker2991')
else if (!username && bot.options.selfcare.username) bot.command(`username ${bot.username}`) else if (!username && bot.options.selfcare.username) bot.command(`username ${bot.username}`)