About
@discordjs/voice
is a TypeScript implementation of the Discord Voice API for Node.js.
Features:
- Send and receive* audio in Discord voice-based channels
- A strong focus on reliability and predictable behaviour
- Horizontal scalability and libraries other than discord.js are supported with custom adapters
- A robust audio processing system that can handle a wide range of audio sources
*Audio receive is not documented by Discord so stable support is not guaranteed
Installation
Node.js 18 or newer is required.
npm install @discordjs/voice
yarn add @discordjs/voice
pnpm add @discordjs/voice
bun add @discordjs/voice
Dependencies
This library has several optional dependencies to support a variety
of different platforms. Install one dependency from each of the
categories shown below. The dependencies are listed in order of
preference for performance. If you can't install one of the options,
try installing another.
Encryption Libraries (npm install):
[!NOTE]
You only need to install one of these libraries if your system does not support aes-256-gcm
(verify by running require('node:crypto').getCiphers().includes('aes-256-gcm')
).
sodium-native
: ^3.3.0sodium
: ^3.0.2@stablelib/xchacha20poly1305
: ^2.0.0@noble/ciphers
: ^1.0.0libsodium-wrappers
: ^0.7.9
Opus Libraries (npm install):
@discordjs/opus
: ^0.4.0opusscript
: ^0.0.7
FFmpeg:
FFmpeg
(installed and added to environment)ffmpeg-static
: ^4.2.7 (npm install)
Examples
The voice-examples repository contains examples on how to use this package. Feel free to check them out if you need a nudge in the right direction.
Links
Contributing
Before creating an issue, please ensure that it hasn't already been reported/suggested, and double-check the
documentation.
See the contribution guide if you'd like to submit a PR.
Help
If you don't understand something in the documentation, you are experiencing problems, or you just need a gentle nudge in the right direction, please don't hesitate to join our official discord.js Server.