A Twitch Bot, in Ruby

98 lines
2.5 KiB

  1. # Message formatting in console
  2. class String
  3. def red; "\e[31m#{self}\e[0m" end
  4. def yellow; "\e[33m#{self}\e[0m" end
  5. def green; "\e[32m#{self}\e[0m" end
  6. def cyan; "\e[36m#{self}\e[0m" end
  7. def bold; "\e[1m#{self}\e[22m" end
  8. end
  9. # Requied packages / modules
  10. require('socket')
  11. require('logger')
  12. # Create logger
  13. if File.file?("log.txt")
  14. File.delete("log.txt") # Clear previous log
  15. end
  16. log = Logger.new("log.txt", formatter: proc {|severity, datetime, progname, msg|
  17. "#{datetime}: #{msg}\n"})
  18. # Required Info
  19. load "credentials.txt"
  20. log.info("Loading \"credentials.txt\"")
  21. require_relative('CommandsHandler') # File for handling commands
  22. log.info("Loading \"CommandsHandler.rb\"")
  23. # -------- IGNORE -------- #
  24. OAUTH.downcase!
  25. BOTNAME.downcase!
  26. CHANNEL.downcase!.gsub!("#", "")
  27. # Save "Preparing to connect" to "log.txt"
  28. log.info("Preparing to connect")
  29. # Variables
  30. socket = TCPSocket.new('irc.chat.twitch.tv', 6667)
  31. running = true
  32. # Authorization Login
  33. socket.puts("PASS #{OAUTH}") # Send the password(oauth) to Twitch
  34. socket.puts("NICK #{BOTNAME}") # Send the botname to Twitch
  35. socket.puts("JOIN ##{CHANNEL}") # Send the channel to Twitch
  36. # Save "Connected!" to "log.txt
  37. log.info("Joining #{CHANNEL.capitalize} as #{BOTNAME.capitalize} using OAUTH Token: #{OAUTH[6,OAUTH.length-16]}" + "*"*16)
  38. Thread.abort_on_exception = true
  39. # Loop (Background Thread) for recieving Twitch chat data
  40. Thread.start do
  41. socket.puts("PRIVMSG ##{CHANNEL} :Connected! PogChamp") # Send "Connected!" to the Twitch channel
  42. log.info("Connected to chat!")
  43. puts "#{BOTNAME} Joined ##{CHANNEL}" # Connection Status
  44. puts "You should be fully connected now" # Connection Status
  45. puts ""
  46. puts "Type \"clear\" to clear terminal"
  47. puts "Type \"project <text>\" to write to project file"
  48. puts "Type \"disconnect\" to disconnect"
  49. puts ""
  50. while (running) do
  51. ready = IO.select([socket])
  52. ready[0].each do |s|
  53. line = s.gets
  54. if line =~ /^/
  55. response, log_msg = HandleCommands(line)
  56. end
  57. if response
  58. socket.puts(response)
  59. response = nil
  60. end
  61. if log_msg
  62. log.info(log_msg)
  63. log_msg = nil
  64. end
  65. end
  66. end
  67. end
  68. # Loop to keep bot going
  69. while (running) do
  70. input = gets.chomp
  71. if input == "clear"
  72. Clear() # Clear console
  73. elsif input == "disconnect"
  74. socket.puts("PRIVMSG ##{CHANNEL} : Disconnected BibleThump")
  75. socket.puts("PART ##{CHANNEL}\r\n")
  76. running = false
  77. exit
  78. end
  79. end