2021-04-21 12:24:52 +05:00
# Discord Player
Complete framework to facilitate music commands using ** [discord.js ](https://discord.js.org )**.
[![downloadsBadge ](https://img.shields.io/npm/dt/discord-player?style=for-the-badge )](https://npmjs.com/discord-player)
[![versionBadge ](https://img.shields.io/npm/v/discord-player?style=for-the-badge )](https://npmjs.com/discord-player)
2021-06-20 19:22:09 +05:00
[![discordBadge ](https://img.shields.io/discord/558328638911545423?style=for-the-badge&color=7289da )](https://androz2091.fr/discord)
[![wakatime ](https://wakatime.com/badge/github/Androz2091/discord-player.svg )](https://wakatime.com/badge/github/Androz2091/discord-player)
> V5 WIP
2021-04-21 12:24:52 +05:00
## Installation
### Install **[discord-player](https://npmjs.com/package/discord-player)**
```sh
$ npm install --save discord-player
```
### Install **[@discordjs/opus](https://npmjs.com/package/@discordjs/opus)**
```sh
$ npm install --save @discordjs/opus
```
### Install FFmpeg or Avconv
- Official FFMPEG Website: ** [https://www.ffmpeg.org/download.html ](https://www.ffmpeg.org/download.html )**
- Node Module (FFMPEG): ** [https://npmjs.com/package/ffmpeg-static ](https://npmjs.com/package/ffmpeg-static )**
- Avconv: ** [https://libav.org/download ](https://libav.org/download )**
# Features
- Simple & easy to use 🤘
- Beginner friendly 😱
- Audio filters 🎸
- Lightweight 🛬
- Custom extractors support 🌌
- Lyrics 📃
- Multiple sources support ✌
- Play in multiple servers at the same time 🚗
## [Documentation](https://discord-player.js.org)
## Getting Started
Here is the code you will need to get started with discord-player. Then, you will be able to use `client.player` everywhere in your code!
```js
const Discord = require("discord.js"),
2021-06-20 19:22:09 +05:00
client = new Discord.Client({ intents: ["GUILD_VOICE_STATES", "GUILD_MESSAGES", "GUILDS"] }),
2021-04-21 12:24:52 +05:00
settings = {
prefix: "!",
token: "Your Discord Token"
};
2021-06-20 19:22:09 +05:00
const { Player, QueryType } = require("discord-player");
2021-04-21 12:24:52 +05:00
// Create a new Player (you don't need any API Key)
const player = new Player(client);
// To easily access the player
client.player = player;
// add the trackStart event so when a song will be played this message will be sent
2021-06-20 19:22:09 +05:00
client.player.on("trackStart", (queue, track) => queue.metadata.channel.send(`Now playing ${track.title}...`))
2021-04-21 12:24:52 +05:00
client.once("ready", () => {
console.log("I'm ready !");
});
client.on("message", async (message) => {
const args = message.content.slice(settings.prefix.length).trim().split(/ +/g);
const command = args.shift().toLowerCase();
// !play Despacito
2021-06-20 19:22:09 +05:00
// will play "Despacito" in the voice channel
if (command === "play") {
if (!message.member.voice.channel) return void message.reply("You are not in a voice channel!");
if (message.guild.me.voice.channel & & message.member.voice.channelID !== message.guild.me.voice.channelID) return void message.reply("You are not in my voice channel!");
const queue = client.player.createQueue(message.guild, {
metadata: message
});
// verify vc connection
try {
if (!queue.connection) await queue.connect(message.member.voice.channel);
} catch {
queue.destroy();
return void message.reply("Could not join your voice channel!");
}
const track = await client.player.search(args[0], {
2021-06-24 10:20:12 +05:00
requestedBy: message.author
2021-06-20 19:22:09 +05:00
}).then(x => x.tracks[1]);
if (!track) return void message.reply("Track not found!");
queue.play(track);
2021-04-21 12:24:52 +05:00
}
});
client.login(settings.token);
```
## Supported websites
By default, discord-player supports **YouTube** , **Spotify** and **SoundCloud** streams only.
### Optional dependencies
Discord Player provides an **Extractor API** that enables you to use your custom stream extractor with it. Some packages have been made by the community to add new features using this API.
#### [@discord-player/extractor](https://github.com/Snowflake107/discord-player-extractors) (optional)
Optional package that adds support for `vimeo` , `reverbnation` , `facebook` , `attachment links` and `lyrics` .
You just need to install it using `npm i --save @discord-player/extractor` (discord-player will automatically detect and use it).
#### [@discord-player/downloader](https://github.com/DevSnowflake/discord-player-downloader) (optional)
`@discord-player/downloader` is an optional package that brings support for +700 websites. The documentation is available [here ](https://github.com/DevSnowflake/discord-player-downloader ).
## Examples of bots made with Discord Player
These bots are made by the community, they can help you build your own!
* [AtlantaBot ](https://github.com/Androz2091/AtlantaBot ) by [Androz2091 ](https://github.com/Androz2091 )
* [Discord-Music ](https://github.com/inhydrox/discord-music ) by [inhydrox ](https://github.com/inhydrox )
* [Music-bot ](https://github.com/ZerioDev/Music-bot ) by [ZerioDev ](https://github.com/ZerioDev )
2021-06-20 19:22:09 +05:00
## Advanced
2021-04-21 12:24:52 +05:00
2021-06-20 19:22:09 +05:00
### Use cookies
2021-04-21 12:24:52 +05:00
```js
const player = new Player(client, {
2021-06-20 19:22:09 +05:00
ytdlOptions: {
2021-04-21 12:24:52 +05:00
requestOptions: {
headers: {
cookie: "YOUR_YOUTUBE_COOKIE"
}
}
}
});
```
2021-06-20 19:22:09 +05:00
### Use custom proxies
2021-04-21 12:24:52 +05:00
```js
const HttpsProxyAgent = require("https-proxy-agent");
// Remove "user:pass@" if you don't need to authenticate to your proxy.
const proxy = "http://user:pass@111.111.111.111:8080";
const agent = HttpsProxyAgent(proxy);
const player = new Player(client, {
2021-06-20 19:22:09 +05:00
ytdlOptions: {
2021-04-21 12:24:52 +05:00
requestOptions: { agent }
}
});
```