- π Table of Contents
- π Introduction
- π¦ Installation
- π Getting started
- β¨ Client related
- β΅ Connection related
- π Guild related
- π Examples
Waterlink is a Lavalink API wrapper written in Go.
go get -u github.com/lukasl-dev/waterlink/v2For the further guides, a Lavalink instance is used, which uses the following application.yml configuration:
server:
port: 2333
address: 0.0.0.0
lavalink:
server:
password: "youshallnotpass"creds := waterlink.Credentials{
Authorization: "youshallnotpass",
}
client, err := waterlink.NewClient("http://localhost:2333", creds)res, err := client.LoadTracks(query.Of("https://www.youtube.com/watch?v=dQw4w9WgXcQ"))res, err := client.LoadTracks(query.YouTube("Never Gonna Give You Up"))res, err := client.LoadTracks(query.SoundCloud("Never Gonna Give You Up"))info, err := client.DecodeTrack(
"QAAAoQIAPFJpY2sgQXN0bGV5IC0gTmV2ZXIgR29ubmEgR2l2ZSBZb3UgVXAgKE9mZmljaWFsIE11c2ljIFZpZGVvKQALUmljayBBc3RsZXkAAAAAAANACAALZFF3NHc5V2dYY1EAAQAraHR0cHM6Ly93d3cueW91dHViZS5jb20vd2F0Y2g/dj1kUXc0dzlXZ1hjUQAHeW91dHViZQAAAAAAAAAA",
)tracks, err := client.DecodeTracks([]string{
"QAAAoQIAPFJpY2sgQXN0bGV5IC0gTmV2ZXIgR29ubmEgR2l2ZSBZb3UgVXAgKE9mZmljaWFsIE11c2ljIFZpZGVvKQALUmljayBBc3RsZXkAAAAAAANACAALZFF3NHc5V2dYY1EAAQAraHR0cHM6Ly93d3cueW91dHViZS5jb20vd2F0Y2g/dj1kUXc0dzlXZ1hjUQAHeW91dHViZQAAAAAAAAAA",
})The opts parameter is optional. In this example, it is used to register an EventHandler. If this is not needed, omit it.
creds := waterlink.Credentials{
Authorization: "youshallnotpass", // password of the Lavalink instance
UserID: 0, // id of the bot user
}
opts := waterlink.ConnectionOptions{
EventHandler: waterlink.EventHandlerFunc(func(evt interface{}) {
fmt.Printf("%s received\n", reflect.TypeOf(evt))
}),
}
conn, err := waterlink.Open("ws://localhost:2333", creds, opts)To restore a past session, its resume key can be defined in the credentials.
creds := waterlink.Credentials{
Authorization: "youshallnotpass", // password of the Lavalink instance
UserID: 0, // id of the bot user
ResumeKey: "myResumeKey", // the resume key of the previous session
}Configures a resume key with a timeout of 5 minutes.
err := conn.ConfigureResuming("myResumeKey", 5*time.Minute)err := conn.DisableResuming()A guild is necessary to access its audio player. The function does not check whether the bot user is on this guild.
g := conn.Guild(0) // id of the guild to accessA guild can be obtained via its own ID with the use of a connection.
See Getting a guild
err := g.Destroy()This function is primarily performed inside a 3rd party libraries' event listener.
See Examples
err := g.UpdateVoice("session", "token", "endpoint")The params parameter is optional. It can be used to specify more information. If this is not needed, omit it.
params := waterlink.PlayParams{
StartTime: 0,
EndTime: 0,
Volume: 0,
NoReplace: false,
Pause: false,
}
err := g.PlayTrack(t, params) // `t` is the preloaded track to playerr := g.Stop()err := g.SetPaused(true)err := g.Seek(25 * time.Second) // seek to 25 secondserr := g.UpdateVolume(25) // 25%Octave is a simple music bot written by myself. It uses discordgo as its Discord library.