aqualink
Version:
An Lavalink client, focused in pure performance and features
450 lines (360 loc) โข 13.7 kB
Markdown
<div align="center">
<p align="center">
<img src="https://capsule-render.vercel.app/api?type=wave&color=0099FF&height=300§ion=header&text=Aqualink&fontSize=90&fontAlignY=35&animation=twinkling&fontColor=ffffff&desc=The%20Ultimate%20Lavalink%20Wrapper&descSize=25&descAlignY=60" />
</p>
[](https://www.npmjs.com/package/aqualink)
[](https://www.npmjs.com/package/aqualink)
[](https://github.com/ToddyTheNoobDud/AquaLink/stargazers)
[](https://discord.gg/K4CVv84VBC)
<br />
<p align="center">
<img src="https://readme-typing-svg.herokuapp.com?font=Montserrat&duration=3000&pause=1000&color=0099FF¢er=true&vCenter=true&width=600&lines=Powerful+Audio+Streaming+for+Discord+Bots;Optimized+for+Lavalink+v4+%26+Node.js;Industry-Leading+Performance;Easy+to+Implement%2C+Hard+to+Master" />
</p>
</div>
<div align="center">
<h3>๐ REIMAGINING AUDIO STREAMING FOR DISCORD ๐</h3>
<h4>Experience crystal-clear audio with unmatched stability</h4>
</div>
<br />
## ๐ Why Choose Aqualink?
<div align="center">
<table>
<tr>
<td align="center" width="33%">
<h3>๐</h3>
<h4>Performance First</h4>
<p>Optimized architecture with 50% less latency than other wrappers</p>
</td>
<td align="center" width="33%">
<h3>๐ ๏ธ</h3>
<h4>Developer Friendly</h4>
<p>Intuitive API with extensive documentation and CJS/ESM support</p>
</td>
<td align="center" width="33%">
<h3>๐</h3>
<h4>Extendable</h4>
<p>Plugin ecosystem for custom functionality and seamless integration</p>
</td>
</tr>
</table>
</div>
## ๐ฆ Installation
**Latest Stable Release: `v2.13.0`** โข **Choose your preferred package manager below**
<details>
<summary><strong>๐ฆ NPM (Most Popular)</strong></summary>
```bash
# ๐ฏ Stable release (recommended for production)
npm install aqualink
# ๐ง Latest development build
npm install ToddyTheNoobDud/aqualink
```
</details>
<details>
<summary><strong>๐งถ Yarn (Fast & Reliable)</strong></summary>
```bash
# ๐ฏ Stable release (recommended for production)
yarn add aqualink
# ๐ง Latest development build
yarn add ToddyTheNoobDud/aqualink
```
</details>
<details>
<summary><strong>โก Bun (Lightning Fast)</strong></summary>
```bash
# ๐ฏ Stable release (recommended for production)
bun add aqualink
# ๐ง Latest development build
bun add ToddyTheNoobDud/aqualink
```
</details>
<details>
<summary><strong>๐ฆ pnpm (Space Efficient)</strong></summary>
```bash
# ๐ฏ Stable release (recommended for production)
pnpm add aqualink
# ๐ง Latest development build
pnpm add ToddyTheNoobDud/aqualink
```
</details>
## ๐ฅ Feature Highlights
<div align="center">
<table>
<tr>
<td align="center" width="25%">
<img src="https://img.icons8.com/fluent/48/000000/filter.png"/>
<h4>Advanced Filters</h4>
<p>EQ, Bass Boost, Nightcore & more</p>
</td>
<td align="center" width="25%">
<img src="https://img.icons8.com/fluent/48/000000/cloud-backup-restore.png"/>
<h4>Fail-Safe System</h4>
<p>Auto-reconnect & queue preservation</p>
</td>
<td align="center" width="25%">
<img src="https://img.icons8.com/fluent/48/000000/bar-chart.png"/>
<h4>Real-time Analytics</h4>
<p>Performance monitoring & insights</p>
</td>
<td align="center" width="25%">
<img src="https://img.icons8.com/fluent/48/000000/settings.png"/>
<h4>Customizable</h4>
<p>Adapt to your specific needs</p>
</td>
</tr>
</table>
</div>
## ๐ฆ Resources
<div align="center">
<a href="https://discord.gg/BNrPCvgrCf">
<img src="https://img.shields.io/badge/Support_Server-3498db?style=for-the-badge&logo=discord&logoColor=white" />
</a>
</div>
## ๐ป Quick Start
```bash
npm install aqualink discord.js
```
```javascript
const { Aqua } = require("aqualink");
const { Client, GatewayIntentBits, Events } = require("discord.js");
const client = new Client({
intents: [
GatewayIntentBits.Guilds,
GatewayIntentBits.GuildMembers,
GatewayIntentBits.GuildMessages,
GatewayIntentBits.MessageContent,
GatewayIntentBits.GuildVoiceStates
]
});
const nodes = [
{
host: "127.0.0.1",
password: "your_password",
port: 2333,
ssl: false,
name: "main-node"
}
];
const aqua = new Aqua(client, nodes, {
defaultSearchPlatform: "ytsearch",
restVersion: "v4",
autoResume: true,
infiniteReconnects: true,
loadBalancer: 'LeastLoad',
leaveOnEnd: false
});
client.aqua = aqua;
client.once(Events.Ready, () => {
client.aqua.init(client.user.id);
console.log(`Logged in as ${client.user.tag}`);
});
client.on(Events.Raw, (d) => {
if (![Events.VoiceStateUpdate, Events.VoiceServerUpdate].includes(d.t)) return;
client.aqua.updateVoiceState(d);
});
client.on(Events.MessageCreate, async (message) => {
if (message.author.bot || !message.content.startsWith("!play")) return;
const query = message.content.slice(6).trim();
if (!query) return message.channel.send("Please provide a song to play.");
// Check if user is in a voice channel
if (!message.member.voice.channel) {
return message.channel.send("You need to be in a voice channel to play music!");
}
const player = client.aqua.createConnection({
guildId: message.guild.id,
voiceChannel: message.member.voice.channel.id,
textChannel: message.channel.id,
deaf: true,
});
try {
const resolve = await client.aqua.resolve({ query, requester: message.member });
const { loadType, tracks, playlistInfo } = resolve;
if (loadType === 'playlist') {
for (const track of tracks) {
player.queue.add(track);
}
message.channel.send(`Added ${tracks.length} songs from ${playlistInfo.name}.`);
} else if (loadType === 'search' || loadType === 'track') {
const track = tracks[0];
player.queue.add(track);
message.channel.send(`Added **${track.title}** to the queue.`);
} else {
return message.channel.send("No results found.");
}
if (!player.playing && !player.paused) {
player.play();
}
} catch (error) {
console.error("Playback error:", error);
message.channel.send("An error occurred while trying to play the song.");
}
});
client.aqua.on("nodeConnect", (node) => {
console.log(`Node connected: ${node.name}`);
});
client.aqua.on("nodeError", (node, error) => {
console.log(`Node "${node.name}" encountered an error: ${error.message}.`);
});
client.aqua.on('trackStart', (player, track) => {
const channel = client.channels.cache.get(player.textChannel);
if (channel) channel.send(`Now playing: **${track.title}**`);
});
client.aqua.on('queueEnd', (player) => {
const channel = client.channels.cache.get(player.textChannel);
if (channel) channel.send('The queue has ended.');
player.destroy();
});
client.login("YOUR_DISCORD_BOT_TOKEN");
```
### Additional Commands You Can Add:
```javascript
client.on(Events.MessageCreate, async (message) => {
if (message.content === "!skip") {
const player = client.aqua.players.get(message.guild.id);
if (player) {
player.skip();
message.channel.send("โญ๏ธ Skipped current track!");
}
}
});
client.on(Events.MessageCreate, async (message) => {
if (message.content === "!stop") {
const player = client.aqua.players.get(message.guild.id);
if (player) {
player.destroy();
message.channel.send("โน๏ธ Stopped playback and cleared queue!");
}
}
});
```
## ๐ Featured Projects
<div align="center">
<table>
<tr>
<td align="center" width="33%">
<img width="120" height="120" src="https://img.icons8.com/fluent/240/000000/water-element.png"/>
<br/>
<img src="https://img.shields.io/badge/Kenium-00bfff?style=for-the-badge&logo=discord&logoColor=white" /><br />
<a href="https://discord.com/oauth2/authorize?client_id=1202232935311495209">Add to Discord</a>
</td>
<td align="center" width="33%">
<img width="120" height="120" src="https://cdn.discordapp.com/attachments/1347414750463660032/1365654298989690930/soya1.jpg?ex=680e182d&is=680cc6ad&hm=3055de34e2af31a3a430f52b147a00215f8b88c8dcc9363cab5359c50ce8d75f&"/>
<br/>
<img src="https://img.shields.io/badge/SoyaMusic-22c55e?style=for-the-badge&logo=discord&logoColor=white" /><br />
<a href="https://discord.com/oauth2/authorize?client_id=997906613082013868&permissions=281357446481&integration_type=0&scope=bot+applications.commands">Add to Discord</a>
</td>
</tr>
</table>
</div>
[View All Projects โ](https://github.com/ToddyTheNoobDud/AquaLink#used-by)
</div>
**300+** weekly downloads โข **3+** GitHub stars โข **3+** Discord bots
</div>
## ๐ Documentation
For detailed usage, API references, and examples, check out our official documentation:
[](https://aqualink-6006388d.mintlify.app)
๐ **Get Started Quickly**
- Installation guide
- API methods
- Advanced features
- Troubleshooting
๐ Visit: **[Aqualink Docs](https://aqualink-6006388d.mintlify.app)**
## ๐ Premium Bots Using Aqualink
| Bot | Invite Link | Features |
|-----|-------------|----------|
| Kenium | [Add to Discord](https://discord.com/oauth2/authorize?client_id=1202232935311495209) | Audio streaming, Discord integration |
| Soya Music | [Add to Discord](https://discord.com/oauth2/authorize?client_id=997906613082013868&permissions=281357446481&integration_type=0&scope=bot+applications.commands) | Audio streaming, Discord integration |
## ๐ ๏ธ Advanced Features
<div align="center">
<table>
<tr>
<td>
<h4>๐๏ธ Audio Filters</h4>
<ul>
<li>Equalizer (15-band)</li>
<li>Bass Boost & Bass Cut</li>
<li>Nightcore & Vaporwave</li>
<li>8D Audio & Rotation</li>
<li>Karaoke & Channel Mixing</li>
</ul>
</td>
<td>
<h4>๐ Queue Management</h4>
<ul>
<li>Shuffle & Loop modes</li>
<li>Queue history & navigation</li>
<li>Auto playlist continuation</li>
<li>Skip voting systems</li>
<li>Playlist import/export</li>
</ul>
</td>
<td>
<h4>๐ Monitoring</h4>
<ul>
<li>Resource utilization</li>
<li>Performance metrics</li>
<li>Automatic issue detection</li>
<li>Node health tracking</li>
<li>Load balancing</li>
</ul>
</td>
</tr>
</table>
</div>
## ๐ฅ Contributors
<div align="center">
<table>
<tbody>
<tr>
<td align="center" valign="top" width="50%">
<a href="https://github.com/southctrl">
<img src="https://avatars.githubusercontent.com/u/134554554?v=4?s=100" width="100px;" alt="southctrl"/>
<br />
<sub><b>southctrl</b></sub>
</a>
<br />
<a href="#code-pomicee" title="Code">๐ป</a>
<a href="#doc-pomicee" title="Documentation">๐</a>
</td>
<td align="center" valign="top" width="50%">
<a href="https://github.com/ToddyTheNoobDud">
<img src="https://avatars.githubusercontent.com/u/86982643?v=4?s=100" width="100px;" alt="ToddyTheNoobDud"/>
<br />
<sub><b>ToddyTheNoobDud</b></sub>
</a>
<br />
<a href="#code-ToddyTheNoobDud" title="Code">๐ป</a>
<a href="#doc-ToddyTheNoobDud" title="Documentation">๐</a>
</td>
<td align="center" valign="top" width="80%">
<a href="https://github.com/SoulDevs">
<img src="https://avatars.githubusercontent.com/u/114820381?v=4" width="100px;" alt="SoulDevs"/>
<br />
<sub><b>SoulDevs</b></sub>
</a>
<br />
<a href="#code-SoulDevs" title="Code">๐ป</a>
</td>
</tr>
</tbody>
</table>
<br />
[Become a contributor โ](CONTRIBUTING.md)
</div>
## ๐ค Contributing
<div align="center">
We welcome contributions from developers of all skill levels! Whether it's adding features, fixing bugs, or improving documentation.
[](CONTRIBUTING.md)
</div>
## ๐ฌ Community & Support
<div align="center">
Join our thriving community of developers and bot creators!
[](https://discord.gg/K4CVv84VBC)
[](https://github.com/ToddyTheNoobDud/AquaLink/discussions)
</div>
<div align="center">
<br />
<p align="center">
<img src="https://capsule-render.vercel.app/api?type=wave&color=0099FF&height=100§ion=footer" />
</p>
<sub>Built with ๐ by the Aqualink Team</sub>
</div>