Added reset command
This commit is contained in:
parent
803d977e27
commit
1586180246
|
@ -36,6 +36,9 @@ Moves MumbleDJ into `channel` if it exists.
|
||||||
####`!reload`
|
####`!reload`
|
||||||
Reloads `mumbledj.gcfg` to retrieve updated configuration settings.
|
Reloads `mumbledj.gcfg` to retrieve updated configuration settings.
|
||||||
|
|
||||||
|
####`!reset`
|
||||||
|
Resets the song queue.
|
||||||
|
|
||||||
####`!kill`
|
####`!kill`
|
||||||
Safely cleans the bot environment and disconnects from the server. Please use this command to stop the bot instead of force closing, as the kill command deletes any remaining songs in the `~/.mumbledj/songs` directory.
|
Safely cleans the bot environment and disconnects from the server. Please use this command to stop the bot instead of force closing, as the kill command deletes any remaining songs in the `~/.mumbledj/songs` directory.
|
||||||
|
|
||||||
|
|
45
commands.go
45
commands.go
|
@ -88,6 +88,13 @@ func parseCommand(user *gumble.User, username, command string) {
|
||||||
} else {
|
} else {
|
||||||
user.Send(NO_PERMISSION_MSG)
|
user.Send(NO_PERMISSION_MSG)
|
||||||
}
|
}
|
||||||
|
// Reset command
|
||||||
|
case dj.conf.Aliases.ResetAlias:
|
||||||
|
if dj.HasPermission(username, dj.conf.Permissions.AdminReset) {
|
||||||
|
reset(username)
|
||||||
|
} else {
|
||||||
|
user.Send(NO_PERMISSION_MSG)
|
||||||
|
}
|
||||||
// Kill command
|
// Kill command
|
||||||
case dj.conf.Aliases.KillAlias:
|
case dj.conf.Aliases.KillAlias:
|
||||||
if dj.HasPermission(username, dj.conf.Permissions.AdminKill) {
|
if dj.HasPermission(username, dj.conf.Permissions.AdminKill) {
|
||||||
|
@ -262,16 +269,26 @@ func reload(user *gumble.User) {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// Performs reset functionality. Clears the song queue, stops playing audio, and deletes all
|
||||||
|
// remaining songs in the ~/.mumbledj/songs directory.
|
||||||
|
func reset(username string) {
|
||||||
|
dj.queue.queue = dj.queue.queue[:0]
|
||||||
|
if err := dj.audioStream.Stop(); err == nil {
|
||||||
|
if err := deleteSongs(); err == nil {
|
||||||
|
dj.client.Self().Channel().Send(fmt.Sprintf(QUEUE_RESET_HTML, username), false)
|
||||||
|
} else {
|
||||||
|
panic(err)
|
||||||
|
}
|
||||||
|
} else {
|
||||||
|
panic(err)
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
// Performs kill functionality. First cleans the ~/.mumbledj/songs directory to get rid of any
|
// Performs kill functionality. First cleans the ~/.mumbledj/songs directory to get rid of any
|
||||||
// excess m4a files. The bot then safely disconnects from the server.
|
// excess m4a files. The bot then safely disconnects from the server.
|
||||||
func kill() {
|
func kill() {
|
||||||
songsDir := fmt.Sprintf("%s/.mumbledj/songs", dj.homeDir)
|
if err := deleteSongs(); err != nil {
|
||||||
if err := os.RemoveAll(songsDir); err != nil {
|
panic(err)
|
||||||
panic(errors.New("An error occurred while deleting the audio files."))
|
|
||||||
} else {
|
|
||||||
if err := os.Mkdir(songsDir, 0777); err != nil {
|
|
||||||
panic(errors.New("An error occurred while recreating the songs directory."))
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
if err := dj.client.Disconnect(); err == nil {
|
if err := dj.client.Disconnect(); err == nil {
|
||||||
fmt.Println("Kill successful. Goodbye!")
|
fmt.Println("Kill successful. Goodbye!")
|
||||||
|
@ -280,3 +297,17 @@ func kill() {
|
||||||
panic(errors.New("An error occurred while disconnecting from the server."))
|
panic(errors.New("An error occurred while disconnecting from the server."))
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// Deletes songs from ~/.mumbledj/songs.
|
||||||
|
func deleteSongs() error {
|
||||||
|
songsDir := fmt.Sprintf("%s/.mumbledj/songs", dj.homeDir)
|
||||||
|
if err := os.RemoveAll(songsDir); err != nil {
|
||||||
|
return errors.New("An error occurred while deleting the audio files.")
|
||||||
|
} else {
|
||||||
|
if err := os.Mkdir(songsDir, 0777); err != nil {
|
||||||
|
return errors.New("An error occurred while recreating the songs directory.")
|
||||||
|
}
|
||||||
|
return nil
|
||||||
|
}
|
||||||
|
return nil
|
||||||
|
}
|
||||||
|
|
|
@ -63,6 +63,10 @@ MoveAlias = "move"
|
||||||
# DEFAULT VALUE: "reload"
|
# DEFAULT VALUE: "reload"
|
||||||
ReloadAlias = "reload"
|
ReloadAlias = "reload"
|
||||||
|
|
||||||
|
# Alias used for queue reset command
|
||||||
|
# DEFAULT VALUE: "reset"
|
||||||
|
ResetAlias = "reset"
|
||||||
|
|
||||||
# Alias used for kill command
|
# Alias used for kill command
|
||||||
# DEFAULT VALUE: "kill"
|
# DEFAULT VALUE: "kill"
|
||||||
KillAlias = "kill"
|
KillAlias = "kill"
|
||||||
|
@ -107,6 +111,10 @@ AdminMove = true
|
||||||
# DEFAULT VALUE: true
|
# DEFAULT VALUE: true
|
||||||
AdminReload = true
|
AdminReload = true
|
||||||
|
|
||||||
|
# Make reset an admin command?
|
||||||
|
# DEFAULT VALUE: true
|
||||||
|
AdminReset = true
|
||||||
|
|
||||||
# Make kill an admin command?
|
# Make kill an admin command?
|
||||||
# DEFAULT VALUE: true (I recommend never changing this to false)
|
# DEFAULT VALUE: true (I recommend never changing this to false)
|
||||||
AdminKill = true
|
AdminKill = true
|
||||||
|
|
|
@ -34,6 +34,7 @@ type DjConfig struct {
|
||||||
VolumeAlias string
|
VolumeAlias string
|
||||||
MoveAlias string
|
MoveAlias string
|
||||||
ReloadAlias string
|
ReloadAlias string
|
||||||
|
ResetAlias string
|
||||||
KillAlias string
|
KillAlias string
|
||||||
}
|
}
|
||||||
Permissions struct {
|
Permissions struct {
|
||||||
|
@ -45,6 +46,7 @@ type DjConfig struct {
|
||||||
AdminVolume bool
|
AdminVolume bool
|
||||||
AdminMove bool
|
AdminMove bool
|
||||||
AdminReload bool
|
AdminReload bool
|
||||||
|
AdminReset bool
|
||||||
AdminKill bool
|
AdminKill bool
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -60,6 +60,7 @@ func (q *SongQueue) Len() int {
|
||||||
|
|
||||||
// OnItemFinished event. Deletes item that just finished playing, then queues the next item.
|
// OnItemFinished event. Deletes item that just finished playing, then queues the next item.
|
||||||
func (q *SongQueue) OnItemFinished() {
|
func (q *SongQueue) OnItemFinished() {
|
||||||
|
if q.Len() != 0 {
|
||||||
if q.CurrentItem().ItemType() == "playlist" {
|
if q.CurrentItem().ItemType() == "playlist" {
|
||||||
if err := q.CurrentItem().(*Playlist).songs.CurrentItem().(*Song).Delete(); err == nil {
|
if err := q.CurrentItem().(*Playlist).songs.CurrentItem().(*Song).Delete(); err == nil {
|
||||||
if q.CurrentItem().(*Playlist).skipped == true {
|
if q.CurrentItem().(*Playlist).skipped == true {
|
||||||
|
@ -95,9 +96,11 @@ func (q *SongQueue) OnItemFinished() {
|
||||||
panic(err)
|
panic(err)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
func (q *SongQueue) PrepareAndPlayNextItem() {
|
func (q *SongQueue) PrepareAndPlayNextItem() {
|
||||||
|
if q.Len() != 0 {
|
||||||
if q.CurrentItem().ItemType() == "playlist" {
|
if q.CurrentItem().ItemType() == "playlist" {
|
||||||
if err := q.CurrentItem().(*Playlist).songs.CurrentItem().(*Song).Download(); err == nil {
|
if err := q.CurrentItem().(*Playlist).songs.CurrentItem().(*Song).Download(); err == nil {
|
||||||
q.CurrentItem().(*Playlist).songs.CurrentItem().(*Song).Play()
|
q.CurrentItem().(*Playlist).songs.CurrentItem().(*Song).Play()
|
||||||
|
@ -117,4 +120,5 @@ func (q *SongQueue) PrepareAndPlayNextItem() {
|
||||||
q.OnItemFinished()
|
q.OnItemFinished()
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -101,3 +101,8 @@ const PLAYLIST_SKIP_ADDED_HTML = `
|
||||||
const VOLUME_SUCCESS_HTML = `
|
const VOLUME_SUCCESS_HTML = `
|
||||||
<b>%s</b> has changed the volume to <b>%.2f</b>.
|
<b>%s</b> has changed the volume to <b>%.2f</b>.
|
||||||
`
|
`
|
||||||
|
|
||||||
|
// Message shown to users when a user successfully resets the SongQueue.
|
||||||
|
const QUEUE_RESET_HTML = `
|
||||||
|
<b>%s</b> has cleared the song queue.
|
||||||
|
`
|
||||||
|
|
Reference in a new issue