Security News
Node.js EOL Versions CVE Dubbed the "Worst CVE of the Year" by Security Experts
Critics call the Node.js EOL CVE a misuse of the system, sparking debate over CVE standards and the growing noise in vulnerability databases.
discord-player-youtubei
Advanced tools
An unofficial package to test the use of youtubei in discord-player v6.
This is a preview the v7 version of the YouTube system that discord-player will be using made backwards compatiable with v6.
$ npm install discord-player-youtubei
# ----------- or -----------
$ yarn add discord-player-youtubei
import { YoutubeiExtractor } from "discord-player-youtubei"
const player = useMainPlayer() // or new Player()
player.extractors.register(YoutubeiExtractor, {})
const { YoutubeiExtractor } = require("discord-player-youtubei")
const player = useMainPlayer() // or new Player()
player.extractors.register(YoutubeiExtractor, {})
I have seen many people registering the extractor in their commands. DO NOT DO THIS
As of 1.2.1
, discord-player-youtubei will detect if you are signed in or not and will use YouTube music streaming system. If this is not available, the extractor will use normal YouTube.
You can override this behavior using the overrideBridgeMode
option. See the extractor options below for more information regarding the types
[!WARNING] Recent developments have lead to the follow piece of code not working as intended. Please use cookies instead.
First run the following command
$ npx --no discord-player-youtubei
The token will be printed out shortly
In case of errors, you can directly run the generateOauthTokens
function exported by discord-player-youtubei
import { YoutubeiExtractor } from "discord-player-youtubei"
const player = useMainPlayer()
/**
* getOauthTokens is not a real function exported by discord-player-youtubei.
* It is simply a placeholder for the actual oauth tokens
*
* Do not just put in access token. Put in the entire string.
*/
const oauthTokens = getOauthTokens() // The tokens printed from step above
player.extractors.register(YoutubeiExtractor, {
authentication: oauthTokens
})
name | type | description | required |
---|---|---|---|
useClient | InnerTubeClient | Which client to get the stream from | false |
highWaterMark | number | How many bytes the stream can hold. The more bytes allocated, the smoother the stream at the cost of more memory usage | false |
name | type | description |
---|---|---|
authentication | string | The auth token |
overrideDownloadOptions | DownloadOptions | Override the default download options |
createStream | fn (q, ext): Promise<string|Readable> | Override the streaming function |
signOutOnDeactive | boolean | Revoke the tokens after deactivation |
overrideBridgeMode | "ytmusic" or "yt" | Override the bridging behavior |
streamOptions | StreamOptions | Configure streaming behavior |
disablePlayer | boolean | Disable the JavaScript player. Use ANDORID client for streaming when using this |
innertubeConfigRaw | InntertubeConfigRaw | Options passed to .create() |
trustedTokens | TrustedTokenConfig | The trusted tokens passed to YouTube to avoid bans |
cookie | string | The cookies passed to innertube similar to ytdl cookies |
proxy | ProxyAgent | Define a proxy to route all the requests |
peers | PeerInfo | Stream from peers allowing to bypass some IP block |
Rename of GeneratorReturnData
All properties are required
name | type | description |
---|---|---|
visitorData | string | The visitor data of the PoToken |
poToken | string | The trusted token of the YouTube client |
name | type | description |
---|---|---|
url | string | The base URL of the peer |
parse | ParserFunction ? | Parse the URL for the peer for streaming |
RAW: (url: string, id: string) => string
name | index | type | description |
---|---|---|---|
url | 0 | string | The base URL of the peer |
id | 1 | string | The YouTube video ID |
The function must return a string
that is a URL that returns an audio stream when requested
export interface StreamOptions {
useClient?: InnerTubeClient;
highWaterMark?: number;
}
export interface RefreshInnertubeOptions {
filePath: string;
interval?: number;
}
export interface PeerInfo {
url: string;
parse?: (url: string, id: string) => string;
}
export type TrustedTokenConfig = {
poToken: string;
visitorData: string;
};
export type QueryBridgeModes = Partial<
Record<SearchQueryType, "yt" | "ytmusic">
> & { default?: "yt" | "ytmusic" };
export interface YoutubeiOptions {
authentication?: string;
overrideDownloadOptions?: DownloadOptions;
createStream?: (
q: Track,
extractor: YoutubeiExtractor,
) => Promise<string | Readable>;
signOutOnDeactive?: boolean;
streamOptions?: StreamOptions;
overrideBridgeMode?: "ytmusic" | "yt" | QueryBridgeModes;
disablePlayer?: boolean;
ignoreSignInErrors?: boolean;
innertubeConfigRaw?: InnerTubeConfig;
trustedTokens?: TrustedTokenConfig;
cookie?: string;
proxy?: ProxyAgent;
peers?: PeerInfo[];
}
class | function | params | static | description |
---|---|---|---|---|
YoutubeiExtractor | setClientMode | InnerTubeClient | true | Set the innertube client on the fly |
Try installing an alpha or a beta build using npm install discord-player-youtubei@alpha
or npm install discord-player-youtubei@beta
. If no beta has been released, you can test the edge version by installing directly from github using npm install github:retrouser955/discord-player-youtubei --save
If this still does not work or you installed a version that is lower than the main version, feel free to open an issue on our GitHub page
If you know how to fix it, please clone this repository and send us a pull request. As this is an open source project, any contributions are welcome!
Just star this repo!
Streaming from YouTube is against their Terms of Service (ToS). Refer to LEGAL.md
to view the risks using YouTube.
FAQs
An unofficial package to test the use of youtubei in discord-player v6.
The npm package discord-player-youtubei receives a total of 1,232 weekly downloads. As such, discord-player-youtubei popularity was classified as popular.
We found that discord-player-youtubei demonstrated a healthy version release cadence and project activity because the last version was released less than a year ago. It has 0 open source maintainers collaborating on the project.
Did you know?
Socket for GitHub automatically highlights issues in each pull request and monitors the health of all your open source dependencies. Discover the contents of your packages and block harmful activity before you install or update your dependencies.
Security News
Critics call the Node.js EOL CVE a misuse of the system, sparking debate over CVE standards and the growing noise in vulnerability databases.
Security News
cURL and Go security teams are publicly rejecting CVSS as flawed for assessing vulnerabilities and are calling for more accurate, context-aware approaches.
Security News
Bun 1.2 enhances its JavaScript runtime with 90% Node.js compatibility, built-in S3 and Postgres support, HTML Imports, and faster, cloud-first performance.