Did some work on Song and SongQueue classes

This commit is contained in:
Matthieu Grieger 2014-11-17 21:02:08 -08:00
parent 61850651d9
commit 3455ab0ff2
3 changed files with 125 additions and 9 deletions

View file

@ -4,6 +4,7 @@
require "mumble-ruby" require "mumble-ruby"
require_relative "config" require_relative "config"
require_relative "song_queue"
# Class that defines MumbleDJ behavior. # Class that defines MumbleDJ behavior.
class MumbleDJ class MumbleDJ
@ -21,6 +22,7 @@ class MumbleDJ
@server_address = server_address @server_address = server_address
@server_port = server_port @server_port = server_port
@default_channel = default_channel @default_channel = default_channel
@song_queue = SongQueue.new
Mumble.configure do |conf| Mumble.configure do |conf|
conf.sample_rate = 48000 conf.sample_rate = 48000
@ -79,9 +81,18 @@ class MumbleDJ
else else
@client.text_user(@sender, "The URL you provided was not valid.") @client.text_user(@sender, "The URL you provided was not valid.")
end end
else
@client.text_user(@sender, NO_PERMISSION_MSG)
end end
when SKIP_ALIAS when SKIP_ALIAS
puts("Skip command request.") if has_permission?(ADMIN_SKIP, @sender)
if OUTPUT_ENABLED
puts("#{@sender} has voted to skip the current song.")
end
@song_queue.get_current_song.add_skip(@sender)
else
@client.text_user(@sender, NO_PERMISSION_MSG)
end
when VOLUME_ALIAS when VOLUME_ALIAS
puts("Volume command request.") puts("Volume command request.")
when MOVE_ALIAS when MOVE_ALIAS
@ -91,11 +102,18 @@ class MumbleDJ
rescue Mumble::ChannelNotFound rescue Mumble::ChannelNotFound
@client.text_user(@sender, "The channel you provided does not exist.") @client.text_user(@sender, "The channel you provided does not exist.")
end end
else
@client.text_user(@sender, NO_PERMISSION_MSG)
end end
# This one doesn't work for some reason. Gotta do some testing.
when KILL_ALIAS when KILL_ALIAS
puts("Kill command request.") if has_permission?(ADMIN_KILL, @sender)
disconnect
else
@client.text_user(@sender, NO_PERMISSION_MSG)
end
else else
puts("The command you have entered is not valid.") @client.text_user(@sender, INVALID_COMMAND_MSG)
end end
end end
end end
@ -108,12 +126,6 @@ class MumbleDJ
end end
end end
# Attempts to add the requested song to the queue, returns true if the
# song was successfully queued, false otherwise.
def song_add_successful?(song_url, sender)
end
# Safely disconnects the bot from the server. # Safely disconnects the bot from the server.
def disconnect def disconnect
@client.disconnect @client.disconnect

37
mumbledj/song.rb Normal file
View file

@ -0,0 +1,37 @@
# MumbleDJ v2
# By Matthieu Grieger
# song.rb
# Base Song class that defines default behavior for any kind of song.
class Song
# Starts the song.
def start
end
# Gets the name of the user who submitted the song.
def get_submitter
return @submitter
end
# Adds a skipper to the skips array for the current song.
def add_skip(username)
end
end
class YouTubeSong < Song
# Initializes the YouTubeSong object and retrieves the song title,
# duration, and thumbnail URL from the YouTube API.
def initialize(url, submitter)
@url = url
@submitter = submitter
@skips = []
# TODO: Retrieve YouTube information
@song_title = ""
@song_duration = ""
@song_thumbnail_url = ""
end
end

67
mumbledj/song_queue.rb Normal file
View file

@ -0,0 +1,67 @@
# MumbleDJ v2
# By Matthieu Grieger
# song_queue.rb
require_relative "song"
# A specialized SongQueue class that handles queueing/unqueueing songs
# and other actions.
class SongQueue
# Initializes a new song queue.
def initialize
@queue = []
end
# Checks if song already exists in the queue, and adds it if it doesn't
# already exist.
def add_song(url, submitter)
# TODO: Determine which kind of URL is given (probably using regex),
# and instantiate the correct Song object.
# Example for a YouTube URL given below.
if @queue.empty?
song = YouTubeSong.new(url, submitter)
@queue.push(song)
else
@queue.each do |song|
if song.url == url
song = YouTubeSong.new(url, submitter)
@queue.push(song)
end
end
end
end
# Processes a song delete request. Searches the queue for songs with
# titles containing the keyword. If found, the song is deleted if the
# username of the user who requested the deletion matches the
# username of who originally added the song.
def delete_song?(keyword, username)
if not @queue.empty?
@queue.each do |song|
if song.song_title.includes?(keyword)
if song.get_submitter == username
@queue.delete(song)
return true
end
end
end
return false
else
return false
end
end
# Returns a formatted string that contains information about the next
# song in the queue.
def peek_next
end
# Returns the current Song object from the queue.
def get_current_song
return @queue[0]
end
end