2020-04-10 02:40:52 +00:00
const db = require ( "../utils/database.js" ) ;
exports . run = async ( message , args ) => {
2020-04-12 20:59:23 +00:00
if ( ! message . member . permission . has ( "administrator" ) && message . member . id !== process . env . OWNER ) return ` ${ message . author . mention } , you need to be an administrator to enable/disable me! ` ;
2020-04-10 02:40:52 +00:00
if ( args . length === 0 ) return ` ${ message . author . mention } , you need to provide whether I should be enabled or disabled in this channel! ` ;
if ( args [ 0 ] !== "disable" && args [ 0 ] !== "enable" ) return ` ${ message . author . mention } , that's not a valid option! ` ;
2020-07-10 17:07:24 +00:00
const guildDB = await db . query ( "SELECT * FROM guilds WHERE guild_id = $1" , [ message . channel . guild . id ] ) ;
2020-04-10 02:40:52 +00:00
if ( args [ 0 ] . toLowerCase ( ) === "disable" ) {
if ( args [ 1 ] && args [ 1 ] . match ( /^<?[@#]?[&!]?\d+>?$/ ) && args [ 1 ] >= 21154535154122752 ) {
const id = args [ 1 ] . replace ( "@" , "" ) . replace ( "#" , "" ) . replace ( "!" , "" ) . replace ( "&" , "" ) . replace ( "<" , "" ) . replace ( ">" , "" ) ;
2020-07-10 17:07:24 +00:00
if ( guildDB . rows [ 0 ] . disabled . includes ( id ) ) return ` ${ message . author . mention } , I'm already disabled in this channel! ` ;
guildDB . rows [ 0 ] . disabled . push ( id ) ;
2020-04-10 02:40:52 +00:00
} else {
2020-07-10 17:07:24 +00:00
if ( guildDB . rows [ 0 ] . disabled . includes ( message . channel . id ) ) return ` ${ message . author . mention } , I'm already disabled in this channel! ` ;
guildDB . rows [ 0 ] . disabled . push ( message . channel . id ) ;
2020-04-10 02:40:52 +00:00
}
2020-07-10 17:07:24 +00:00
await db . query ( "UPDATE guilds SET disabled = $1 WHERE guild_id = $2" , [ guildDB . rows [ 0 ] . disabled , message . channel . guild . id ] ) ;
return ` ${ message . author . mention } , I have been disabled in this channel. To re-enable me, just run \` ${ guildDB . rows [ 0 ] . prefix } channel enable \` . ` ;
2020-04-10 02:40:52 +00:00
} else if ( args [ 0 ] . toLowerCase ( ) === "enable" ) {
if ( args [ 1 ] && args [ 1 ] . match ( /^<?[@#]?[&!]?\d+>?$/ ) && args [ 1 ] >= 21154535154122752 ) {
const id = args [ 1 ] . replace ( "@" , "" ) . replace ( "#" , "" ) . replace ( "!" , "" ) . replace ( "&" , "" ) . replace ( "<" , "" ) . replace ( ">" , "" ) ;
2020-07-10 17:07:24 +00:00
if ( ! guildDB . rows [ 0 ] . disabled . includes ( id ) ) return ` ${ message . author . mention } , I'm not disabled in that channel! ` ;
guildDB . rows [ 0 ] . disabled = guildDB . rows [ 0 ] . disabled . filter ( item => item !== id ) ;
2020-04-10 02:40:52 +00:00
} else {
2020-07-10 17:07:24 +00:00
if ( ! guildDB . rows [ 0 ] . disabled . includes ( message . channel . id ) ) return ` ${ message . author . mention } , I'm not disabled in this channel! ` ;
guildDB . rows [ 0 ] . disabled = guildDB . rows [ 0 ] . disabled . filter ( item => item !== message . channel . id ) ;
2020-04-10 02:40:52 +00:00
}
2020-07-10 17:07:24 +00:00
await db . query ( "UPDATE guilds SET disabled = $1 WHERE guild_id = $2" , [ guildDB . rows [ 0 ] . disabled , message . channel . guild . id ] ) ;
2020-04-10 02:40:52 +00:00
return ` ${ message . author . mention } , I have been re-enabled in this channel. ` ;
}
} ;
exports . category = 1 ;
exports . help = "Enables/disables me in a channel" ;
exports . params = "[enable/disable] {id}" ;