Product
Socket Now Supports uv.lock Files
Socket now supports uv.lock files to ensure consistent, secure dependency resolution for Python projects and enhance supply chain security.
A fast and easy music library for Discord.js Version 14 made with play-dl and @discordjs/voice
npm i dismusic
# or yarn
yarn add dismusic
First you must intstall ffmpeg-static (or just ffmpeg) and @discordjs/opus. (Python might be required for @discordjs/opus)
npm i ffmpeg-static @discordjs/opus
Next, we can create a discord js client
const {
Client,
GatewayIntentBits: Intents,
Partials
} = require('discord.js')
const client = new Client(
{
intents: [Intents.Guilds, Intents.GuildVoiceStates, Intents.MessageContent, Intents.GuildMessages],
partials: [Partials.Message]
}
)
Guild Voice State is required for this package
Then we can add dismusic to it
const {
Client,
GatewayIntentBits: Intents,
Partials
} = require('discord.js')
const client = new Client(
{
intents: [Intents.Guilds, Intents.GuildVoiceStates, Intents.MessageContent, Intents.GuildMessages],
partials: [Partials.Message]
}
)
const { Player } = require('dismusic')
client.player = new Player(client, {
spotify: {
client_id: 'spotify Client ID',
client_secret: 'spotify Client Secret',
token: "Spotify Request Token",
market: 'US' // market do not touch if you dont know
}
})
To get the spotify client id, client secret and request token, visit the play-dl docs here
We can then add listeners
const {
Client,
GatewayIntentBits: Intents,
Partials
} = require('discord.js')
const client = new Client(
{
intents: [Intents.Guilds, Intents.GuildVoiceStates, Intents.MessageContent, Intents.GuildMessages],
partials: [Partials.Message]
}
)
const { Player } = require('dismusic')
client.player = new Player(client, {
spotify: {
client_id: 'spotify Client ID',
client_secret: 'spotify Client Secret',
token: "Spotify Request Token",
market: 'US' // market do not touch if you dont know
}
})
client.player.on('trackStart', async (song, queueData) => {
queueData.metaChannel.send(`Started playing track ${song.title}\n\nDuration: \`${song.duration}\`\nURL: ${song.url}\nrequestedBy: ${song.metadata.requestedBy.tag}`)
})
.on('queueEnded', (queueData) => {
queueData.metaChannel.send(`There are no more songs in the queue. Leaving 👋`)
})
client.on('messageCreate', async (message) => {
if(!message.content.startsWith('!')) return
if(message.content.startsWith('!play ')) {
if(!message.member.voice.channelId) return message.channel.send('Please join a voice channel')
if(message.guild.me.voice.channel && message.member.voice.channelId !== message.guild.me.voice.channelId) return message.channel.send('Please join my voice channel')
const args = message.content.replace('!play ', '')
const existQueue = await client.player.existQueue(message.guildId)
if(existQueue) {
const existingQueue = await client.player.getQueue(message.guildId)
message.channel.send(`🔍 | Searching for ${args}`).then(async msg => {
const song = await existingQueue.addSong(args, {
metadata: {
requestedBy: message.author
}
})
msg.edit(`Added ${song.title} to the queue\n\nDuration: \`${song.duration}\`\nURL: ${song.url}`)
})
return
}
const queue = await client.player.createQueue(message.guildId, {
queueData: {
metaChannel: message.channel
}
})
try {
queue.connect(message.member.voice.channel)
} catch {
return message.channel.send('there was an error while connecting to your voice channel')
}
const song = await queue.playSong(args, {
metadata: {
requestedBy: message.author
}
})
message.channel.send(`Joined <#${message.member.voice.channelId}> and started playing ${song.title}\n\nDuration: \`${song.duration}\`\nURL: ${song.url}`)
} else if (message.content === '!stop') {
if(!message.member.voice.channelId) return message.channel.send('Please join a voice channel')
if(message.guild.me.voice.channel && message.member.voice.channelId !== message.guild.me.voice.channelId) return message.channel.send('Please join my voice channel')
const queue = await client.player.getQueue(message.guildId)
queue.stop()
} else if (message.content === '!queue') {
if(!message.member.voice.channelId) return message.channel.send('Please join a voice channel')
if(message.guild.me.voice.channel && message.member.voice.channelId !== message.guild.me.voice.channelId) return message.channel.send('Please join my voice channel')
const queue = await client.player.getQueue(message.guildId)
const queueSongs = []
for(const songs of queue.songs) {
queueSongs.push(`${songs.title} ([link](${songs.url}))`)
}
message.channel.send({
embeds: [{
title: 'Queue',
description: queueSongs.join('\n')
}]
})
} else if (message.content === '!pause') {
if(!message.member.voice.channelId) return message.channel.send('Please join a voice channel')
if(message.guild.me.voice.channel && message.member.voice.channelId !== message.guild.me.voice.channelId) return message.channel.send('Please join my voice channel')
const queue = await client.player.getQueue(message.guildId)
queue.pause()
} else if (message.content === '!resume') {
if(!message.member.voice.channelId) return message.channel.send('Please join a voice channel')
if(message.guild.me.voice.channel && message.member.voice.channelId !== message.guild.me.voice.channelId) return message.channel.send('Please join my voice channel')
const queue = await client.player.getQueue(message.guildId)
queue.resume()
} else if (message.content === '!skip') {
if(!message.member.voice.channelId) return message.channel.send('Please join a voice channel')
if(message.guild.me.voice.channel && message.member.voice.channelId !== message.guild.me.voice.channelId) return message.channel.send('Please join my voice channel')
const queue = await client.player.getQueue(message.guildId)
message.channel.send(`Skipping ${queue.songs[0].title}`)
queue.skip()
}
})
client.login('your bot token')
⚠ This package is still in development. If you encountered a bug, open an issue at our github page
This is the data which the queue will return if you use createQueue
or getQueue
functions
Skip. Type: Function
pause. Type: Function
resume. Type: Function
isPaused. Type: Boolean
connect (params: voiceChannel). Type: Function
stop. Type: Function
playSong (params: query, options) Type: Function
Song Options:
metadata. The data you want to keep with the song
songs. Type: Array. Current tracks in the queue. use songs[0] to get the current song
song object:
title. Type: String, The title of the song
description. Type: String, The description of the song
duration. Type: String, The duration of the song represented in minutes and seconds
url: Type: String, The url of the song
metadata: Type: Object, The metadata of the song
addSong. Type: Function (params: query, options). Add tracks to the queue
Song Options:
metadata. The data you want to keep with the song
If you encountered any problems or have a question, feel free to join our discord server
FAQs
An easy music package for discord.js version 14
The npm package dismusic receives a total of 147 weekly downloads. As such, dismusic popularity was classified as not popular.
We found that dismusic demonstrated a not healthy version release cadence and project activity because the last version was released a year ago. It has 1 open source maintainer 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.
Product
Socket now supports uv.lock files to ensure consistent, secure dependency resolution for Python projects and enhance supply chain security.
Research
Security News
Socket researchers have discovered multiple malicious npm packages targeting Solana private keys, abusing Gmail to exfiltrate the data and drain Solana wallets.
Security News
PEP 770 proposes adding SBOM support to Python packages to improve transparency and catch hidden non-Python dependencies that security tools often miss.