rebuild
This commit is contained in:
parent
1c99c751cf
commit
ada97a2286
3 changed files with 191 additions and 0 deletions
44
docs/extractors/extractor.md
Normal file
44
docs/extractors/extractor.md
Normal file
|
@ -0,0 +1,44 @@
|
||||||
|
# Discord Player Extractor API
|
||||||
|
The Extractor API allows you to build your own stream extractor for **Discord Player**.
|
||||||
|
|
||||||
|
# Example Extractor
|
||||||
|
Your extractor should have 2 methods (required):
|
||||||
|
- `validate(query): boolean`
|
||||||
|
|
||||||
|
This method is called by Discord Player while validating the query provided via `Player.play()`. (Note that only `string` queries are passed to your extractor)
|
||||||
|
|
||||||
|
- `getInfo(query): object`
|
||||||
|
|
||||||
|
This method is used by Discord Player to create `Track` object. You can return your data here that gets passed to `Track`.
|
||||||
|
Your info must be similar to this:
|
||||||
|
|
||||||
|
```js
|
||||||
|
{
|
||||||
|
// the title
|
||||||
|
title: "Extracted by custom extractor",
|
||||||
|
// the duration in ms
|
||||||
|
duration: 20000,
|
||||||
|
// the thumbnail
|
||||||
|
thumbnail: data.thumbnail,
|
||||||
|
// engine, can be Readable streams or link to raw stream that gets played
|
||||||
|
engine: data.streamURL,
|
||||||
|
// number of views
|
||||||
|
views: 0,
|
||||||
|
// author of this stream
|
||||||
|
author: data.artist.name,
|
||||||
|
// description
|
||||||
|
description: "",
|
||||||
|
// link of this stream
|
||||||
|
url: data.url
|
||||||
|
}
|
||||||
|
```
|
||||||
|
- `important: boolean`
|
||||||
|
|
||||||
|
You can mark your Extractor as `important` by adding `important: true` to your extractor object. Doing this will disable rest of the extractors that comes after your extractor and use your extractor to get data. By default, it is set to `false`.
|
||||||
|
|
||||||
|
- `version: string`
|
||||||
|
|
||||||
|
This should be the version of your extractor. It is not really important and is set to `0.0.0` by default.
|
||||||
|
|
||||||
|
# Examples
|
||||||
|
### You can check out **[@discord-player/extractor](https://github.com/Snowflake107/discord-player-extractors)**
|
139
docs/general/welcome.md
Normal file
139
docs/general/welcome.md
Normal file
|
@ -0,0 +1,139 @@
|
||||||
|
# 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)
|
||||||
|
|
||||||
|
## 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"),
|
||||||
|
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 the song "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](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)
|
||||||
|
|
||||||
|
## FAQ
|
||||||
|
|
||||||
|
### How to use cookies
|
||||||
|
|
||||||
|
```js
|
||||||
|
const player = new Player(client, {
|
||||||
|
ytdlDownloadOptions: {
|
||||||
|
requestOptions: {
|
||||||
|
headers: {
|
||||||
|
cookie: "YOUR_YOUTUBE_COOKIE"
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
});
|
||||||
|
```
|
||||||
|
|
||||||
|
### How to use custom proxies
|
||||||
|
|
||||||
|
```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, {
|
||||||
|
ytdlDownloadOptions: {
|
||||||
|
requestOptions: { agent }
|
||||||
|
}
|
||||||
|
});
|
||||||
|
```
|
8
docs/index.yml
Normal file
8
docs/index.yml
Normal file
|
@ -0,0 +1,8 @@
|
||||||
|
- name: General
|
||||||
|
files:
|
||||||
|
- name: Welcome
|
||||||
|
path: welcome.md
|
||||||
|
- name: Extractors
|
||||||
|
files:
|
||||||
|
- name: Extractors API
|
||||||
|
path: extractor.md
|
Loading…
Reference in a new issue