Shoukaku
A stable and updated wrapper around Lavalink
The ShipGirl Project, feat Shoukaku; ⓒ Kancolle
Features
✅ Stable
✅ Documented
✅ Updated
✅ Extendable
✅ Very cute (Very Important)
Supported Libraries
Refer to /src/connectors for list of supported libraries + how to support other libraries
Documentation
https://deivu.github.io/Shoukaku/
Small code snippet examples
Initializing the library (Using Connector Discord.JS)
const { Client } = require('discord.js');
const { Shoukaku, Connectors } = require('shoukaku');
const Nodes = [{
name: 'Localhost',
url: 'localhost:6969',
auth: 'marin_kitagawa'
}];
const client = new Client();
const shoukaku = new Shoukaku(new Connectors.DiscordJS(client), Nodes);
shoukaku.on('error', (_, error) => console.error(error));
client.login('token');
Searching and joining a channel (Async Function Implementation)
const node = shoukaku.getNode();
if (!node) return;
const result = await node.rest.resolve('scsearch:snowhalation');
if (!result?.tracks.length) return;
const metadata = result.tracks.shift();
const player = await node.joinVoiceChannel({
guildId: 'your_guild_id',
channelId: 'your_channel_id',
shardId: 0
});
Playing a track and changing a playback option (in this example, volume)
player
.playTrack(metadata.track)
.setVolume(0.5);
Shoukaku's options
Option | Type | Description |
---|
resume | boolean | Whether to resume a connection on disconnect to Lavalink |
resumeKey | string | Resume key for Lavalink |
resumeTimeout | number | Timeout before resuming a connection in seconds |
reconnectTries | number | Number of times to try and reconnect to Lavalink before giving up |
reconnectInterval | number | Timeout before trying to reconnect in milliseconds |
restTimeout | number | Time to wait for a response from the Lavalink REST API before giving up in milliseconds |
moveOnDisconnect | boolean | Whether to move players to a different Lavalink node when a node disconnects |
userAgent | string | User Agent to use when making requests to Lavalink |
structures | Object{rest?, player?} | Custom structures for shoukaku to use |
Plugins list
Open a pr to add your plugin here
Name | Link | Description |
---|
..... | ........ | .......... |
Creating Plugins
Shoukaku has now official supports for plugins. However, implementing this is up to the developers that is interested on doing it
Shoukaku support modification on Rest.ts and Player.ts
To apply your plugin, put the extended classes on ShoukakuOptions.structures. Example below
const { Client } = require('discord.js');
const { Shoukaku, Rest, Connectors } = require('shoukaku');
class CustomRest extends Rest { };
const Nodes = [{
name: 'Localhost',
url: 'localhost:6969',
auth: 'marin_kitagawa'
}];
const ShoukakuOptions = { structures: { rest: CustomRest } }
const client = new Client();
const shoukaku = new Shoukaku(new Connectors.DiscordJS(client), Nodes, ShoukakuOptions);
Other Links
Support (#Development) | Lavalink
Implementation (Discord.JS)
https://github.com/Deivu/Kongou
Made with ❤ by:
@Sāya#0113