Boto/node/boto.js

52 lines
1.5 KiB
JavaScript

// B O T O
// ---
require('dotenv').config();
const tmi = require('tmi.js');
const rp = require('request-promise'); // For RNG
const colors = require('colors');
console.log(process.env.API_HOST);
const client = new tmi.Client({
options: { debug: true },
connection: {
secure: true,
reconnect: true
},
identity: {
username: process.env.TTV_BOT_USERNAME,
password: process.env.TTV_BOT_OAUTH
},
channels: [ process.env.TTV_CHANNELS ]
});
client.connect();
//import { rnguser } from "./rng.js";
//rnguser();
// SCAN MSG | START
client.on('message', (channel, tags, message, self) => {
if(self) return;
const badges = tags.badges || {}; // Scan Badges
const isBroadcaster = badges.broadcaster; // Define Streamer
const isMod = badges.moderator; // Define Mod
const isModUp = isBroadcaster || isMod; // Permission Merge = Mod+Streamer
const isSub = badges.subscriber || badges.founder; // Define Subs
const botUserState = client.userstate[channel]; // MOD Status Check
const amMod = botUserState !== undefined && botUserState.mod === true; // Define Mod Status
if(self || !message.startsWith('!')) return; // Command Parser
const args = message.slice(1).split(' ');
const command = args.shift().toLowerCase(); // !COMMAND => command
// import { cmd_general } from "./cmd/general.js";
// cmd_general();
// import { cmd_subs } from "./cmd/subs.js";
// cmd_suds();
// import { cmd_mods } from "./cmd/mods.js";
// cmd_mods();
}); // SCAN MSG | END