No description
Find a file
Snowflake107 9d5f065582 fix docs
2021-04-21 10:53:33 +05:45
.github 👷 Fix publish workflow 2021-04-19 17:44:37 +02:00
docs fix docs 2021-04-21 10:53:33 +05:45
src fix docs 2021-04-21 10:53:33 +05:45
.gitignore fix docs 2021-04-21 10:53:33 +05:45
.npmignore fix docs 2021-04-21 10:53:33 +05:45
.prettierrc format 2021-04-04 23:29:45 +05:45
CODE_OF_CONDUCT.md CODE_OF_CONDUCT 2021-04-18 23:29:12 +05:45
CONTRIBUTING.md CONTRIBUTING 2021-04-18 23:32:18 +05:45
jsdoc.json fix docs 2021-04-21 10:53:33 +05:45
LICENSE merge master 2021-04-18 23:20:18 +05:45
package.json fix docs 2021-04-21 10:53:33 +05:45
README.md grammatical mistake 2021-04-19 20:31:58 +05:45
tsconfig.json merge master 2021-04-18 23:20:18 +05:45
tslint.json format 2021-04-06 18:43:46 +05:45
yarn.lock fix docs 2021-04-21 10:53:33 +05:45

Discord Player

Complete framework to facilitate music commands using discord.js.

downloadsBadge versionBadge

Installation

Install discord-player

$ npm install --save discord-player

Install @discordjs/opus

$ npm install --save @discordjs/opus

Install FFmpeg or Avconv

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

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!

const Discord = require("discord.js"),
client = new Discord.Client,
settings = {
    prefix: "!",
    token: "Your Discord Token"
};

const { Player } = require("discord-player");

// 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
client.player.on("trackStart", (message, track) => message.channel.send(`Now playing ${track.title}...`))

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
    // will play "Despacito" in the voice channel
    if(command === "play"){
        client.player.play(message, args[0]);
        // as we registered the event above, no need to send a success message here
    }

});

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 (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 (optional)

@discord-player/downloader is an optional package that brings support for +700 websites. The documentation is available here.

Examples of bots made with Discord Player

These bots are made by the community, they can help you build your own!

FAQ

How to use cookies?

const player = new Player(client, {
    ytdlDownloadOptions: {
        requestOptions: {
            headers: {
                cookie: "YOUR_YOUTUBE_COOKIE"
            }
        }
    }
});

How to use custom proxies?

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, {
    ytdlDownloadOptions: {
        requestOptions: { agent }
    }
});