discord-player 7.0.0-dev.5 → 7.0.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/README.md +1 -1
- package/dist/index.d.ts +2204 -2159
- package/dist/index.js +651 -604
- package/package.json +7 -12
package/dist/index.js
CHANGED
|
@@ -1,18 +1,16 @@
|
|
|
1
1
|
"use strict";
|
|
2
|
-
var __create = Object.create;
|
|
3
2
|
var __defProp = Object.defineProperty;
|
|
4
3
|
var __getOwnPropDesc = Object.getOwnPropertyDescriptor;
|
|
5
4
|
var __getOwnPropNames = Object.getOwnPropertyNames;
|
|
6
|
-
var __getProtoOf = Object.getPrototypeOf;
|
|
7
5
|
var __hasOwnProp = Object.prototype.hasOwnProperty;
|
|
8
6
|
var __typeError = (msg) => {
|
|
9
7
|
throw TypeError(msg);
|
|
10
8
|
};
|
|
11
9
|
var __defNormalProp = (obj, key, value) => key in obj ? __defProp(obj, key, { enumerable: true, configurable: true, writable: true, value }) : obj[key] = value;
|
|
12
|
-
var __name = (
|
|
13
|
-
var __export = (
|
|
10
|
+
var __name = (target, value) => __defProp(target, "name", { value, configurable: true });
|
|
11
|
+
var __export = (target, all) => {
|
|
14
12
|
for (var name in all)
|
|
15
|
-
__defProp(
|
|
13
|
+
__defProp(target, name, { get: all[name], enumerable: true });
|
|
16
14
|
};
|
|
17
15
|
var __copyProps = (to, from, except, desc) => {
|
|
18
16
|
if (from && typeof from === "object" || typeof from === "function") {
|
|
@@ -22,15 +20,7 @@ var __copyProps = (to, from, except, desc) => {
|
|
|
22
20
|
}
|
|
23
21
|
return to;
|
|
24
22
|
};
|
|
25
|
-
var __reExport = (
|
|
26
|
-
var __toESM = (mod, isNodeMode, target2) => (target2 = mod != null ? __create(__getProtoOf(mod)) : {}, __copyProps(
|
|
27
|
-
// If the importer is in node compatibility mode or this is not an ESM
|
|
28
|
-
// file that has been converted to a CommonJS file using a Babel-
|
|
29
|
-
// compatible transform (i.e. "__esModule" has not been set), then set
|
|
30
|
-
// "default" to the CommonJS "module.exports" for node compatibility.
|
|
31
|
-
isNodeMode || !mod || !mod.__esModule ? __defProp(target2, "default", { value: mod, enumerable: true }) : target2,
|
|
32
|
-
mod
|
|
33
|
-
));
|
|
23
|
+
var __reExport = (target, mod, secondTarget) => (__copyProps(target, mod, "default"), secondTarget && __copyProps(secondTarget, mod, "default"));
|
|
34
24
|
var __toCommonJS = (mod) => __copyProps(__defProp({}, "__esModule", { value: true }), mod);
|
|
35
25
|
var __publicField = (obj, key, value) => __defNormalProp(obj, typeof key !== "symbol" ? key + "" : key, value);
|
|
36
26
|
var __accessCheck = (obj, member, msg) => member.has(obj) || __typeError("Cannot " + msg);
|
|
@@ -127,6 +117,189 @@ var import_promises = require("timers/promises");
|
|
|
127
117
|
// src/fabric/Track.ts
|
|
128
118
|
var import_discord = require("discord.js");
|
|
129
119
|
|
|
120
|
+
// src/errors/index.ts
|
|
121
|
+
var _DiscordPlayerError = class _DiscordPlayerError extends Error {
|
|
122
|
+
constructor(code, message) {
|
|
123
|
+
super(message);
|
|
124
|
+
__publicField(this, "code");
|
|
125
|
+
__publicField(this, "timestamp", Date.now());
|
|
126
|
+
this.name = this.constructor.name;
|
|
127
|
+
this.code = code;
|
|
128
|
+
if (Error.captureStackTrace) {
|
|
129
|
+
Error.captureStackTrace(this, this.constructor);
|
|
130
|
+
}
|
|
131
|
+
}
|
|
132
|
+
toJSON() {
|
|
133
|
+
return {
|
|
134
|
+
name: this.constructor.name,
|
|
135
|
+
code: this.code,
|
|
136
|
+
message: this.message,
|
|
137
|
+
timestamp: this.timestamp
|
|
138
|
+
};
|
|
139
|
+
}
|
|
140
|
+
};
|
|
141
|
+
__name(_DiscordPlayerError, "DiscordPlayerError");
|
|
142
|
+
var DiscordPlayerError = _DiscordPlayerError;
|
|
143
|
+
var _OutOfSpaceError = class _OutOfSpaceError extends DiscordPlayerError {
|
|
144
|
+
constructor(target, capacity, total) {
|
|
145
|
+
super(ErrorCodes.ERR_OUT_OF_SPACE, `Max capacity reached for ${target} (Capacity ${capacity}/Total ${total})`);
|
|
146
|
+
}
|
|
147
|
+
};
|
|
148
|
+
__name(_OutOfSpaceError, "OutOfSpaceError");
|
|
149
|
+
var OutOfSpaceError = _OutOfSpaceError;
|
|
150
|
+
var _InvalidArgTypeError = class _InvalidArgTypeError extends DiscordPlayerError {
|
|
151
|
+
constructor(target, expectation, found) {
|
|
152
|
+
super(ErrorCodes.ERR_INVALID_ARG_TYPE, `Expected ${target} to be "${expectation}", received "${found}"`);
|
|
153
|
+
}
|
|
154
|
+
};
|
|
155
|
+
__name(_InvalidArgTypeError, "InvalidArgTypeError");
|
|
156
|
+
var InvalidArgTypeError = _InvalidArgTypeError;
|
|
157
|
+
var _NoResultError = class _NoResultError extends DiscordPlayerError {
|
|
158
|
+
constructor(message) {
|
|
159
|
+
super(ErrorCodes.ERR_NO_RESULT, message);
|
|
160
|
+
}
|
|
161
|
+
};
|
|
162
|
+
__name(_NoResultError, "NoResultError");
|
|
163
|
+
var NoResultError = _NoResultError;
|
|
164
|
+
var _NotImplementedError = class _NotImplementedError extends DiscordPlayerError {
|
|
165
|
+
constructor(target) {
|
|
166
|
+
super(ErrorCodes.ERR_NOT_IMPLEMENTED, `${target} is not yet implemented`);
|
|
167
|
+
}
|
|
168
|
+
};
|
|
169
|
+
__name(_NotImplementedError, "NotImplementedError");
|
|
170
|
+
var NotImplementedError = _NotImplementedError;
|
|
171
|
+
var _NotExistingError = class _NotExistingError extends DiscordPlayerError {
|
|
172
|
+
constructor(target) {
|
|
173
|
+
super(ErrorCodes.ERR_NOT_EXISTING, `${target} does not exist`);
|
|
174
|
+
}
|
|
175
|
+
};
|
|
176
|
+
__name(_NotExistingError, "NotExistingError");
|
|
177
|
+
var NotExistingError = _NotExistingError;
|
|
178
|
+
var _OutOfRangeError = class _OutOfRangeError extends DiscordPlayerError {
|
|
179
|
+
constructor(target, value, minimum, maximum) {
|
|
180
|
+
super(
|
|
181
|
+
ErrorCodes.ERR_OUT_OF_RANGE,
|
|
182
|
+
`${target} is out of range (Expected minimum ${minimum} and maximum ${maximum}, got ${value})`
|
|
183
|
+
);
|
|
184
|
+
}
|
|
185
|
+
};
|
|
186
|
+
__name(_OutOfRangeError, "OutOfRangeError");
|
|
187
|
+
var OutOfRangeError = _OutOfRangeError;
|
|
188
|
+
var _NoVoiceConnectionError = class _NoVoiceConnectionError extends DiscordPlayerError {
|
|
189
|
+
constructor(message) {
|
|
190
|
+
super(
|
|
191
|
+
ErrorCodes.ERR_NO_VOICE_CONNECTION,
|
|
192
|
+
message || "No voice connection available, maybe connect to a voice channel first?"
|
|
193
|
+
);
|
|
194
|
+
}
|
|
195
|
+
};
|
|
196
|
+
__name(_NoVoiceConnectionError, "NoVoiceConnectionError");
|
|
197
|
+
var NoVoiceConnectionError = _NoVoiceConnectionError;
|
|
198
|
+
var _VoiceConnectionDestroyedError = class _VoiceConnectionDestroyedError extends DiscordPlayerError {
|
|
199
|
+
constructor() {
|
|
200
|
+
super(ErrorCodes.ERR_VOICE_CONNECTION_DESTROYED, "Cannot use destroyed voice connection");
|
|
201
|
+
}
|
|
202
|
+
};
|
|
203
|
+
__name(_VoiceConnectionDestroyedError, "VoiceConnectionDestroyedError");
|
|
204
|
+
var VoiceConnectionDestroyedError = _VoiceConnectionDestroyedError;
|
|
205
|
+
var _NoVoiceChannelError = class _NoVoiceChannelError extends DiscordPlayerError {
|
|
206
|
+
constructor() {
|
|
207
|
+
super(ErrorCodes.ERR_NO_VOICE_CHANNEL, "Could not get the voice channel");
|
|
208
|
+
}
|
|
209
|
+
};
|
|
210
|
+
__name(_NoVoiceChannelError, "NoVoiceChannelError");
|
|
211
|
+
var NoVoiceChannelError = _NoVoiceChannelError;
|
|
212
|
+
var _NoAudioResourceError = class _NoAudioResourceError extends DiscordPlayerError {
|
|
213
|
+
constructor(message) {
|
|
214
|
+
super(ErrorCodes.ERR_NO_AUDIO_RESOURCE, message || "Expected an audio resource");
|
|
215
|
+
}
|
|
216
|
+
};
|
|
217
|
+
__name(_NoAudioResourceError, "NoAudioResourceError");
|
|
218
|
+
var NoAudioResourceError = _NoAudioResourceError;
|
|
219
|
+
var _NoGuildQueueError = class _NoGuildQueueError extends DiscordPlayerError {
|
|
220
|
+
constructor(message) {
|
|
221
|
+
super(ErrorCodes.ERR_NO_GUILD_QUEUE, message || "Expected a guild queue");
|
|
222
|
+
}
|
|
223
|
+
};
|
|
224
|
+
__name(_NoGuildQueueError, "NoGuildQueueError");
|
|
225
|
+
var NoGuildQueueError = _NoGuildQueueError;
|
|
226
|
+
var _NoGuildError = class _NoGuildError extends DiscordPlayerError {
|
|
227
|
+
constructor(message) {
|
|
228
|
+
super(ErrorCodes.ERR_NO_GUILD, message || "Expected a guild");
|
|
229
|
+
}
|
|
230
|
+
};
|
|
231
|
+
__name(_NoGuildError, "NoGuildError");
|
|
232
|
+
var NoGuildError = _NoGuildError;
|
|
233
|
+
var _InfoRequiredError = class _InfoRequiredError extends DiscordPlayerError {
|
|
234
|
+
constructor(target, actual) {
|
|
235
|
+
super(ErrorCodes.ERR_INFO_REQUIRED, `Expected ${target}, found "${actual}"`);
|
|
236
|
+
}
|
|
237
|
+
};
|
|
238
|
+
__name(_InfoRequiredError, "InfoRequiredError");
|
|
239
|
+
var InfoRequiredError = _InfoRequiredError;
|
|
240
|
+
var _SerializationError = class _SerializationError extends DiscordPlayerError {
|
|
241
|
+
constructor() {
|
|
242
|
+
super(ErrorCodes.ERR_SERIALIZATION_FAILED, "Don't know how to serialize this data");
|
|
243
|
+
}
|
|
244
|
+
};
|
|
245
|
+
__name(_SerializationError, "SerializationError");
|
|
246
|
+
var SerializationError = _SerializationError;
|
|
247
|
+
var _DeserializationError = class _DeserializationError extends DiscordPlayerError {
|
|
248
|
+
constructor() {
|
|
249
|
+
super(ErrorCodes.ERR_DESERIALIZATION_FAILED, "Don't know how to deserialize this data");
|
|
250
|
+
}
|
|
251
|
+
};
|
|
252
|
+
__name(_DeserializationError, "DeserializationError");
|
|
253
|
+
var DeserializationError = _DeserializationError;
|
|
254
|
+
var _IllegalHookInvocationError = class _IllegalHookInvocationError extends DiscordPlayerError {
|
|
255
|
+
constructor(target, message) {
|
|
256
|
+
super(
|
|
257
|
+
ErrorCodes.ERR_ILLEGAL_HOOK_INVOCATION,
|
|
258
|
+
`Illegal invocation of ${target} hook.${message ? ` ${message}` : ""}`
|
|
259
|
+
);
|
|
260
|
+
}
|
|
261
|
+
};
|
|
262
|
+
__name(_IllegalHookInvocationError, "IllegalHookInvocationError");
|
|
263
|
+
var IllegalHookInvocationError = _IllegalHookInvocationError;
|
|
264
|
+
var _BridgeFailedError = class _BridgeFailedError extends DiscordPlayerError {
|
|
265
|
+
constructor(id, error) {
|
|
266
|
+
super(
|
|
267
|
+
ErrorCodes.ERR_BRIDGE_FAILED,
|
|
268
|
+
`${id ? `(Extractor Execution Context ID is ${id})` : ""}Failed to bridge this query:
|
|
269
|
+
${error}`
|
|
270
|
+
);
|
|
271
|
+
}
|
|
272
|
+
};
|
|
273
|
+
__name(_BridgeFailedError, "BridgeFailedError");
|
|
274
|
+
var BridgeFailedError = _BridgeFailedError;
|
|
275
|
+
var ErrorCodes = {
|
|
276
|
+
ERR_OUT_OF_SPACE: "ERR_OUT_OF_SPACE",
|
|
277
|
+
ERR_INVALID_ARG_TYPE: "ERR_INVALID_ARG_TYPE",
|
|
278
|
+
ERR_NO_RESULT: "ERR_NO_RESULT",
|
|
279
|
+
ERR_NOT_IMPLEMENTED: "ERR_NOT_IMPLEMENTED",
|
|
280
|
+
ERR_NOT_EXISTING: "ERR_NOT_EXISTING",
|
|
281
|
+
ERR_OUT_OF_RANGE: "ERR_OUT_OF_RANGE",
|
|
282
|
+
ERR_NO_VOICE_CONNECTION: "ERR_NO_VOICE_CONNECTION",
|
|
283
|
+
ERR_VOICE_CONNECTION_DESTROYED: "ERR_VOICE_CONNECTION_DESTROYED",
|
|
284
|
+
ERR_NO_VOICE_CHANNEL: "ERR_NO_VOICE_CHANNEL",
|
|
285
|
+
ERR_INVALID_VOICE_CHANNEL: "ERR_INVALID_VOICE_CHANNEL",
|
|
286
|
+
ERR_NO_RECEIVER: "ERR_NO_RECEIVER",
|
|
287
|
+
ERR_FFMPEG_LOCATOR: "ERR_FFMPEG_LOCATOR",
|
|
288
|
+
ERR_NO_AUDIO_RESOURCE: "ERR_NO_AUDIO_RESOURCE",
|
|
289
|
+
ERR_NO_GUILD_QUEUE: "ERR_NO_GUILD_QUEUE",
|
|
290
|
+
ERR_NO_GUILD: "ERR_NO_GUILD",
|
|
291
|
+
ERR_INFO_REQUIRED: "ERR_INFO_REQUIRED",
|
|
292
|
+
ERR_SERIALIZATION_FAILED: "ERR_SERIALIZATION_FAILED",
|
|
293
|
+
ERR_DESERIALIZATION_FAILED: "ERR_DESERIALIZATION_FAILED",
|
|
294
|
+
ERR_ILLEGAL_HOOK_INVOCATION: "ERR_ILLEGAL_HOOK_INVOCATION",
|
|
295
|
+
ERR_NOT_EXISTING_MODULE: "ERR_NOT_EXISTING_MODULE",
|
|
296
|
+
ERR_BRIDGE_FAILED: "ERR_BRIDGE_FAILED"
|
|
297
|
+
};
|
|
298
|
+
function isDiscordPlayerError(error) {
|
|
299
|
+
return error != null && error instanceof DiscordPlayerError;
|
|
300
|
+
}
|
|
301
|
+
__name(isDiscordPlayerError, "isDiscordPlayerError");
|
|
302
|
+
|
|
130
303
|
// src/utils/TypeUtil.ts
|
|
131
304
|
var _TypeUtil = class _TypeUtil {
|
|
132
305
|
constructor() {
|
|
@@ -154,182 +327,13 @@ var _TypeUtil = class _TypeUtil {
|
|
|
154
327
|
static isError(t) {
|
|
155
328
|
return t instanceof Error;
|
|
156
329
|
}
|
|
330
|
+
static isDiscordPlayerError(t) {
|
|
331
|
+
return isDiscordPlayerError(t);
|
|
332
|
+
}
|
|
157
333
|
};
|
|
158
334
|
__name(_TypeUtil, "TypeUtil");
|
|
159
335
|
var TypeUtil = _TypeUtil;
|
|
160
336
|
|
|
161
|
-
// src/errors/index.ts
|
|
162
|
-
var DiscordPlayerErrors = {
|
|
163
|
-
ERR_OUT_OF_SPACE: {
|
|
164
|
-
name: "ERR_OUT_OF_SPACE",
|
|
165
|
-
type: RangeError,
|
|
166
|
-
createError(target2, capacity, total) {
|
|
167
|
-
return `[${this.constructor.name}] Max capacity reached for ${target2} (Capacity ${capacity}/Total ${total})`;
|
|
168
|
-
}
|
|
169
|
-
},
|
|
170
|
-
ERR_INVALID_ARG_TYPE: {
|
|
171
|
-
name: "ERR_INVALID_ARG_TYPE",
|
|
172
|
-
type: TypeError,
|
|
173
|
-
createError(target2, expectation, found) {
|
|
174
|
-
return `[${this.constructor.name}] Expected ${target2} to be "${expectation}", received "${found}"`;
|
|
175
|
-
}
|
|
176
|
-
},
|
|
177
|
-
ERR_NO_RESULT: {
|
|
178
|
-
name: "ERR_NO_RESULT",
|
|
179
|
-
type: Error,
|
|
180
|
-
createError(message) {
|
|
181
|
-
return `[${this.constructor.name}] ${message}`;
|
|
182
|
-
}
|
|
183
|
-
},
|
|
184
|
-
ERR_NOT_IMPLEMENTED: {
|
|
185
|
-
name: "ERR_NOT_IMPLEMENTED",
|
|
186
|
-
type: Error,
|
|
187
|
-
createError(target2) {
|
|
188
|
-
return `[${this.constructor.name}] ${target2} is not yet implemented`;
|
|
189
|
-
}
|
|
190
|
-
},
|
|
191
|
-
ERR_NOT_EXISTING: {
|
|
192
|
-
name: "ERR_NOT_EXISTING",
|
|
193
|
-
type: Error,
|
|
194
|
-
createError(target2) {
|
|
195
|
-
return `[${this.constructor.name}] ${target2} does not exist`;
|
|
196
|
-
}
|
|
197
|
-
},
|
|
198
|
-
ERR_OUT_OF_RANGE: {
|
|
199
|
-
name: "ERR_OUT_OF_RANGE",
|
|
200
|
-
type: RangeError,
|
|
201
|
-
createError(target2, value, minimum, maximum) {
|
|
202
|
-
return `[${this.constructor.name}] ${target2} is out of range (Expected minimum ${maximum} and maximum ${maximum}, got ${value})`;
|
|
203
|
-
}
|
|
204
|
-
},
|
|
205
|
-
ERR_NO_VOICE_CONNECTION: {
|
|
206
|
-
name: "ERR_NO_VOICE_CONNECTION",
|
|
207
|
-
type: Error,
|
|
208
|
-
createError(message) {
|
|
209
|
-
return `[${this.constructor.name}] ` + (message || "No voice connection available, maybe connect to a voice channel first?");
|
|
210
|
-
}
|
|
211
|
-
},
|
|
212
|
-
ERR_VOICE_CONNECTION_DESTROYED: {
|
|
213
|
-
name: "ERR_VOICE_CONNECTION_DESTROYED",
|
|
214
|
-
type: Error,
|
|
215
|
-
createError() {
|
|
216
|
-
return `[${this.constructor.name}] Cannot use destroyed voice connection`;
|
|
217
|
-
}
|
|
218
|
-
},
|
|
219
|
-
ERR_NO_VOICE_CHANNEL: {
|
|
220
|
-
name: "ERR_NO_VOICE_CHANNEL",
|
|
221
|
-
type: Error,
|
|
222
|
-
createError() {
|
|
223
|
-
return `[${this.constructor.name}] Could not get the voice channel`;
|
|
224
|
-
}
|
|
225
|
-
},
|
|
226
|
-
ERR_INVALID_VOICE_CHANNEL: {
|
|
227
|
-
name: "ERR_INVALID_VOICE_CHANNEL",
|
|
228
|
-
type: Error,
|
|
229
|
-
createError() {
|
|
230
|
-
return `[${this.constructor.name}] Expected a voice channel`;
|
|
231
|
-
}
|
|
232
|
-
},
|
|
233
|
-
ERR_NO_RECEIVER: {
|
|
234
|
-
name: "ERR_NO_RECEIVER",
|
|
235
|
-
type: Error,
|
|
236
|
-
createError(message) {
|
|
237
|
-
return `[${this.constructor.name}] ` + (message || "No voice receiver is available, maybe connect to a voice channel first?");
|
|
238
|
-
}
|
|
239
|
-
},
|
|
240
|
-
ERR_FFMPEG_LOCATOR: {
|
|
241
|
-
name: "ERR_FFMPEG_LOCATOR",
|
|
242
|
-
type: Error,
|
|
243
|
-
createError(message) {
|
|
244
|
-
return `[${this.constructor.name}] ` + message;
|
|
245
|
-
}
|
|
246
|
-
},
|
|
247
|
-
ERR_NO_AUDIO_RESOURCE: {
|
|
248
|
-
name: "ERR_NO_AUDIO_RESOURCE",
|
|
249
|
-
type: Error,
|
|
250
|
-
createError(message) {
|
|
251
|
-
return `[${this.constructor.name}] ` + (message || "Expected an audio resource");
|
|
252
|
-
}
|
|
253
|
-
},
|
|
254
|
-
ERR_NO_GUILD_QUEUE: {
|
|
255
|
-
name: "ERR_NO_GUILD_QUEUE",
|
|
256
|
-
type: Error,
|
|
257
|
-
createError(message) {
|
|
258
|
-
return `[${this.constructor.name}] ` + (message || "Expected a guild queue");
|
|
259
|
-
}
|
|
260
|
-
},
|
|
261
|
-
ERR_NO_GUILD: {
|
|
262
|
-
name: "ERR_NO_GUILD",
|
|
263
|
-
type: Error,
|
|
264
|
-
createError(message) {
|
|
265
|
-
return `[${this.constructor.name}] ` + (message || "Expected a guild");
|
|
266
|
-
}
|
|
267
|
-
},
|
|
268
|
-
ERR_INFO_REQUIRED: {
|
|
269
|
-
name: "ERR_INFO_REQUIRED",
|
|
270
|
-
type: Error,
|
|
271
|
-
createError(target2, actual) {
|
|
272
|
-
return `[${this.constructor.name}] Expected ${target2}, found "${actual}"`;
|
|
273
|
-
}
|
|
274
|
-
},
|
|
275
|
-
ERR_SERIALIZATION_FAILED: {
|
|
276
|
-
name: "ERR_SERIALIZATION_FAILED",
|
|
277
|
-
type: Error,
|
|
278
|
-
createError() {
|
|
279
|
-
return `[${this.type.name}]Don't know how to serialize this data`;
|
|
280
|
-
}
|
|
281
|
-
},
|
|
282
|
-
ERR_DESERIALIZATION_FAILED: {
|
|
283
|
-
name: "ERR_DESERIALIZATION_FAILED",
|
|
284
|
-
type: Error,
|
|
285
|
-
createError() {
|
|
286
|
-
return `[${this.type.name}]Don't know how to deserialize this data`;
|
|
287
|
-
}
|
|
288
|
-
},
|
|
289
|
-
ERR_ILLEGAL_HOOK_INVOCATION: {
|
|
290
|
-
name: "ERR_ILLEGAL_HOOK_INVOCATION",
|
|
291
|
-
type: Error,
|
|
292
|
-
createError(target2, message) {
|
|
293
|
-
return `[${this.type.name}]Illegal invocation of ${target2} hook.${message ? ` ${message}` : ""}`;
|
|
294
|
-
}
|
|
295
|
-
},
|
|
296
|
-
ERR_NOT_EXISTING_MODULE: {
|
|
297
|
-
name: "ERR_NOT_EXISTING_MODULE",
|
|
298
|
-
type: Error,
|
|
299
|
-
createError(target2, description = "") {
|
|
300
|
-
return `[${this.type.name}]${target2} module does not exist. Install it with \`npm install ${target2}\`.${description ? " " + description : ""}`;
|
|
301
|
-
}
|
|
302
|
-
},
|
|
303
|
-
ERR_BRIDGE_FAILED: {
|
|
304
|
-
name: "ERR_BRIDGE_FAILED",
|
|
305
|
-
type: Error,
|
|
306
|
-
createError(id, error) {
|
|
307
|
-
return `[${this.type.name}]${id ? `(Extractor Execution Context ID is ${id})` : ""}Failed to bridge this query:
|
|
308
|
-
${error}`;
|
|
309
|
-
}
|
|
310
|
-
}
|
|
311
|
-
};
|
|
312
|
-
var target = {};
|
|
313
|
-
var handler = {
|
|
314
|
-
get(target2, p, receiver) {
|
|
315
|
-
const err = DiscordPlayerErrors[p];
|
|
316
|
-
if (!err) return Reflect.get(target2, p, receiver);
|
|
317
|
-
return (...args) => {
|
|
318
|
-
const exception = new err.type(err.createError(...args));
|
|
319
|
-
exception.name = err.name;
|
|
320
|
-
return exception;
|
|
321
|
-
};
|
|
322
|
-
}
|
|
323
|
-
};
|
|
324
|
-
var ErrorCodes = (() => {
|
|
325
|
-
const dict = {};
|
|
326
|
-
for (const prop in DiscordPlayerErrors) {
|
|
327
|
-
dict[prop] = prop;
|
|
328
|
-
}
|
|
329
|
-
return Object.freeze(dict);
|
|
330
|
-
})();
|
|
331
|
-
var Exceptions = new Proxy(target, handler);
|
|
332
|
-
|
|
333
337
|
// src/utils/serde.ts
|
|
334
338
|
var import_buffer = require("buffer");
|
|
335
339
|
var SerializedType = /* @__PURE__ */ ((SerializedType2) => {
|
|
@@ -345,14 +349,14 @@ function serialize(data) {
|
|
|
345
349
|
try {
|
|
346
350
|
return data.toJSON();
|
|
347
351
|
} catch {
|
|
348
|
-
throw
|
|
352
|
+
throw new SerializationError();
|
|
349
353
|
}
|
|
350
354
|
}
|
|
351
355
|
__name(serialize, "serialize");
|
|
352
356
|
function deserialize(player, data) {
|
|
353
357
|
if (isTrack(data)) return Track.fromSerialized(player, data);
|
|
354
358
|
if (isPlaylist(data)) return Playlist.fromSerialized(player, data);
|
|
355
|
-
throw
|
|
359
|
+
throw new DeserializationError();
|
|
356
360
|
}
|
|
357
361
|
__name(deserialize, "deserialize");
|
|
358
362
|
function encode(data) {
|
|
@@ -377,6 +381,7 @@ function tryIntoThumbnailString(data) {
|
|
|
377
381
|
__name(tryIntoThumbnailString, "tryIntoThumbnailString");
|
|
378
382
|
|
|
379
383
|
// src/fabric/Track.ts
|
|
384
|
+
var _resource;
|
|
380
385
|
var _Track = class _Track {
|
|
381
386
|
/**
|
|
382
387
|
* Track constructor
|
|
@@ -405,6 +410,7 @@ var _Track = class _Track {
|
|
|
405
410
|
__publicField(this, "live", false);
|
|
406
411
|
__publicField(this, "bridgedExtractor", null);
|
|
407
412
|
__publicField(this, "bridgedTrack", null);
|
|
413
|
+
__privateAdd(this, _resource, null);
|
|
408
414
|
this.title = (0, import_discord.escapeMarkdown)(data.title ?? "");
|
|
409
415
|
this.author = data.author ?? "";
|
|
410
416
|
this.url = data.url ?? "";
|
|
@@ -421,6 +427,25 @@ var _Track = class _Track {
|
|
|
421
427
|
this.cleanTitle = data.cleanTitle ?? Util.cleanTitle(this.title, this.source);
|
|
422
428
|
this.live = data.live ?? false;
|
|
423
429
|
}
|
|
430
|
+
/**
|
|
431
|
+
* Sets audio resource for this track. This is not useful outside of the library.
|
|
432
|
+
* @param resource Audio resource
|
|
433
|
+
*/
|
|
434
|
+
setResource(resource) {
|
|
435
|
+
__privateSet(this, _resource, resource);
|
|
436
|
+
}
|
|
437
|
+
/**
|
|
438
|
+
* Gets audio resource for this track
|
|
439
|
+
*/
|
|
440
|
+
get resource() {
|
|
441
|
+
return __privateGet(this, _resource);
|
|
442
|
+
}
|
|
443
|
+
/**
|
|
444
|
+
* Whether this track has an audio resource
|
|
445
|
+
*/
|
|
446
|
+
get hasResource() {
|
|
447
|
+
return __privateGet(this, _resource) != null;
|
|
448
|
+
}
|
|
424
449
|
/**
|
|
425
450
|
* Request metadata for this track
|
|
426
451
|
*/
|
|
@@ -519,7 +544,7 @@ var _Track = class _Track {
|
|
|
519
544
|
extractor: this.extractor?.identifier ?? null,
|
|
520
545
|
metadata: this.metadata,
|
|
521
546
|
$type: "track" /* Track */,
|
|
522
|
-
$encoder_version:
|
|
547
|
+
$encoder_version: this.player.version
|
|
523
548
|
};
|
|
524
549
|
}
|
|
525
550
|
/**
|
|
@@ -528,8 +553,7 @@ var _Track = class _Track {
|
|
|
528
553
|
* @param data Serialized data
|
|
529
554
|
*/
|
|
530
555
|
static fromSerialized(player, data) {
|
|
531
|
-
if (data.$type !== "track" /* Track */)
|
|
532
|
-
throw Exceptions.ERR_INVALID_ARG_TYPE("data", "SerializedTrack", "malformed data");
|
|
556
|
+
if (data.$type !== "track" /* Track */) throw new InvalidArgTypeError("data", "SerializedTrack", "malformed data");
|
|
533
557
|
const track = new _Track(player, {
|
|
534
558
|
...data,
|
|
535
559
|
requestedBy: data.requested_by ? (() => {
|
|
@@ -566,6 +590,7 @@ var _Track = class _Track {
|
|
|
566
590
|
return await fn(channel, this, options);
|
|
567
591
|
}
|
|
568
592
|
};
|
|
593
|
+
_resource = new WeakMap();
|
|
569
594
|
__name(_Track, "Track");
|
|
570
595
|
var Track = _Track;
|
|
571
596
|
|
|
@@ -650,7 +675,7 @@ var _Playlist = class _Playlist {
|
|
|
650
675
|
id: this.id,
|
|
651
676
|
url: this.url,
|
|
652
677
|
$type: "playlist" /* Playlist */,
|
|
653
|
-
$encoder_version:
|
|
678
|
+
$encoder_version: this.player.version
|
|
654
679
|
};
|
|
655
680
|
}
|
|
656
681
|
/**
|
|
@@ -660,7 +685,7 @@ var _Playlist = class _Playlist {
|
|
|
660
685
|
*/
|
|
661
686
|
static fromSerialized(player, data) {
|
|
662
687
|
if (data.$type !== "playlist" /* Playlist */)
|
|
663
|
-
throw
|
|
688
|
+
throw new InvalidArgTypeError("data", "SerializedPlaylist", "malformed data");
|
|
664
689
|
return new _Playlist(player, {
|
|
665
690
|
...data,
|
|
666
691
|
tracks: data.tracks.map((m) => Track.fromSerialized(player, m))
|
|
@@ -679,7 +704,38 @@ var _Playlist = class _Playlist {
|
|
|
679
704
|
__name(_Playlist, "Playlist");
|
|
680
705
|
var Playlist = _Playlist;
|
|
681
706
|
|
|
682
|
-
// src/
|
|
707
|
+
// src/utils/QueryResolver.ts
|
|
708
|
+
var import_undici = require("undici");
|
|
709
|
+
var spotifySongRegex = /^https?:\/\/(?:embed\.|open\.)(?:spotify\.com\/)(intl-([a-z]|[A-Z])+\/)?(?:track\/|\?uri=spotify:track:)((\w|-){22})(\?si=.+)?$/;
|
|
710
|
+
var spotifyPlaylistRegex = /^https?:\/\/(?:embed\.|open\.)(?:spotify\.com\/)(intl-([a-z]|[A-Z])+\/)?(?:playlist\/|\?uri=spotify:playlist:)((\w|-){22})(\?si=.+)?$/;
|
|
711
|
+
var spotifyAlbumRegex = /^https?:\/\/(?:embed\.|open\.)(?:spotify\.com\/)(intl-([a-z]|[A-Z])+\/)?(?:album\/|\?uri=spotify:album:)((\w|-){22})(\?si=.+)?$/;
|
|
712
|
+
var vimeoRegex = /^(http|https)?:\/\/(www\.|player\.)?vimeo\.com\/(?:channels\/(?:\w+\/)?|groups\/([^/]*)\/videos\/|video\/|)(\d+)(?:|\/\?)$/;
|
|
713
|
+
var reverbnationRegex = /^https:\/\/(www.)?reverbnation.com\/(.+)\/song\/(.+)$/;
|
|
714
|
+
var attachmentRegex = /^https?:\/\/.+$/;
|
|
715
|
+
var appleMusicSongRegex = /^https?:\/\/music\.apple\.com\/.+?\/(song|album)\/.+?(\/.+?\?i=|\/)([0-9]+)$/;
|
|
716
|
+
var appleMusicPlaylistRegex = /^https?:\/\/music\.apple\.com\/.+?\/playlist\/.+\/pl\.(u-|pm-)?[a-zA-Z0-9]+$/;
|
|
717
|
+
var appleMusicAlbumRegex = /^https?:\/\/music\.apple\.com\/.+?\/album\/.+\/([0-9]+)$/;
|
|
718
|
+
var soundcloudTrackRegex = /^https?:\/\/(m.|www.)?soundcloud.com\/(\w|-)+\/(\w|-)+(.+)?$/;
|
|
719
|
+
var soundcloudPlaylistRegex = /^https?:\/\/(m.|www.)?soundcloud.com\/(\w|-)+\/sets\/(\w|-)+(.+)?$/;
|
|
720
|
+
var youtubePlaylistRegex = /^https?:\/\/(www.)?youtube.com\/playlist\?list=((PL|FL|UU|LL|RD|OL)[a-zA-Z0-9-_]{16,41})$/;
|
|
721
|
+
var youtubeVideoURLRegex = /^((?:https?:)?\/\/)?((?:www|m)\.)?((?:youtube\.com|youtu.be))(\/(?:[\w-]+\?v=|embed\/|v\/)?)([\w-]+)(\S+)?$/;
|
|
722
|
+
var youtubeVideoIdRegex = /^[a-zA-Z0-9-_]{11}$/;
|
|
723
|
+
var discordPlayerBlobRegex = /^discord-player:\/\/blob\/\d+$/;
|
|
724
|
+
var DomainsMap = {
|
|
725
|
+
DiscordPlayer: ["discord-player"],
|
|
726
|
+
YouTube: ["youtube.com", "youtu.be", "music.youtube.com", "gaming.youtube.com", "www.youtube.com", "m.youtube.com"],
|
|
727
|
+
Spotify: ["open.spotify.com", "embed.spotify.com"],
|
|
728
|
+
Vimeo: ["vimeo.com", "player.vimeo.com"],
|
|
729
|
+
ReverbNation: ["reverbnation.com"],
|
|
730
|
+
SoundCloud: ["soundcloud.com"],
|
|
731
|
+
AppleMusic: ["music.apple.com"]
|
|
732
|
+
};
|
|
733
|
+
var redirectDomains = /* @__PURE__ */ new Set(
|
|
734
|
+
[
|
|
735
|
+
/^https?:\/\/spotify.link\/[A-Za-z0-9]+$/,
|
|
736
|
+
/^https:\/\/on\.soundcloud\.com\/[a-zA-Z1-9]{0,17}$/
|
|
737
|
+
]
|
|
738
|
+
);
|
|
683
739
|
var QueryType = {
|
|
684
740
|
AUTO: "auto",
|
|
685
741
|
YOUTUBE: "youtube",
|
|
@@ -703,23 +759,131 @@ var QueryType = {
|
|
|
703
759
|
APPLE_MUSIC_PLAYLIST: "appleMusicPlaylist",
|
|
704
760
|
APPLE_MUSIC_SEARCH: "appleMusicSearch",
|
|
705
761
|
FILE: "file",
|
|
706
|
-
AUTO_SEARCH: "autoSearch"
|
|
762
|
+
AUTO_SEARCH: "autoSearch",
|
|
763
|
+
DISCORD_PLAYER_BLOB: "discordPlayerBlob"
|
|
707
764
|
};
|
|
708
|
-
var
|
|
709
|
-
|
|
710
|
-
|
|
711
|
-
|
|
712
|
-
|
|
713
|
-
|
|
714
|
-
|
|
765
|
+
var _QueryResolver = class _QueryResolver {
|
|
766
|
+
/**
|
|
767
|
+
* Query resolver
|
|
768
|
+
*/
|
|
769
|
+
constructor() {
|
|
770
|
+
}
|
|
771
|
+
// eslint-disable-line @typescript-eslint/no-empty-function
|
|
772
|
+
static get regex() {
|
|
773
|
+
return {
|
|
774
|
+
spotifyAlbumRegex,
|
|
775
|
+
spotifyPlaylistRegex,
|
|
776
|
+
spotifySongRegex,
|
|
777
|
+
vimeoRegex,
|
|
778
|
+
reverbnationRegex,
|
|
779
|
+
attachmentRegex,
|
|
780
|
+
appleMusicAlbumRegex,
|
|
781
|
+
appleMusicPlaylistRegex,
|
|
782
|
+
appleMusicSongRegex,
|
|
783
|
+
soundcloudTrackRegex,
|
|
784
|
+
soundcloudPlaylistRegex,
|
|
785
|
+
youtubePlaylistRegex,
|
|
786
|
+
discordPlayerBlobRegex
|
|
787
|
+
};
|
|
788
|
+
}
|
|
789
|
+
/**
|
|
790
|
+
* Pre-resolve redirect urls
|
|
791
|
+
*/
|
|
792
|
+
static async preResolve(query, maxDepth = 5) {
|
|
793
|
+
if (!TypeUtil.isString(query)) throw new InvalidArgTypeError(query, "string", typeof query);
|
|
794
|
+
for (const domain of redirectDomains) {
|
|
795
|
+
if (domain.test(query)) {
|
|
796
|
+
try {
|
|
797
|
+
const res = await (0, import_undici.fetch)(query, {
|
|
798
|
+
method: "GET",
|
|
799
|
+
redirect: "follow"
|
|
800
|
+
});
|
|
801
|
+
if (!res.ok) break;
|
|
802
|
+
if (/^https?:\/\/spotify.app.link\/(.+)$/.test(res.url)) {
|
|
803
|
+
const body = await res.text();
|
|
804
|
+
const target = body.split("https://open.spotify.com/track/")[1].split("?si=")[0];
|
|
805
|
+
if (!target) break;
|
|
806
|
+
return `https://open.spotify.com/track/${target}`;
|
|
807
|
+
}
|
|
808
|
+
return maxDepth < 1 ? res.url : this.preResolve(res.url, maxDepth - 1);
|
|
809
|
+
} catch {
|
|
810
|
+
break;
|
|
811
|
+
}
|
|
812
|
+
}
|
|
813
|
+
}
|
|
814
|
+
return query;
|
|
815
|
+
}
|
|
816
|
+
/**
|
|
817
|
+
* Resolves the given search query
|
|
818
|
+
* @param {string} query The query
|
|
819
|
+
*/
|
|
820
|
+
static resolve(query, fallbackSearchEngine = QueryType.AUTO_SEARCH) {
|
|
821
|
+
if (!TypeUtil.isString(query)) throw new InvalidArgTypeError(query, "string", typeof query);
|
|
822
|
+
if (!query.length) throw new InfoRequiredError("query", String(query));
|
|
823
|
+
const resolver = /* @__PURE__ */ __name((type, query2) => ({ type, query: query2 }), "resolver");
|
|
824
|
+
if (discordPlayerBlobRegex.test(query)) return resolver(QueryType.DISCORD_PLAYER_BLOB, query);
|
|
825
|
+
try {
|
|
826
|
+
const url = new URL(query);
|
|
827
|
+
if (DomainsMap.YouTube.includes(url.host)) {
|
|
828
|
+
query = query.replace(/(m(usic)?|gaming)\./, "").trim();
|
|
829
|
+
const playlistId = url.searchParams.get("list");
|
|
830
|
+
const videoId = url.searchParams.get("v");
|
|
831
|
+
if (playlistId) {
|
|
832
|
+
if (videoId && playlistId.startsWith("RD"))
|
|
833
|
+
return resolver(
|
|
834
|
+
QueryType.YOUTUBE_PLAYLIST,
|
|
835
|
+
`https://www.youtube.com/watch?v=${videoId}&list=${playlistId}`
|
|
836
|
+
);
|
|
837
|
+
return resolver(QueryType.YOUTUBE_PLAYLIST, `https://www.youtube.com/playlist?list=${playlistId}`);
|
|
838
|
+
}
|
|
839
|
+
if (_QueryResolver.validateId(query) || _QueryResolver.validateURL(query))
|
|
840
|
+
return resolver(QueryType.YOUTUBE_VIDEO, query);
|
|
841
|
+
return resolver(fallbackSearchEngine, query);
|
|
842
|
+
} else if (DomainsMap.Spotify.includes(url.host)) {
|
|
843
|
+
query = query.replace(/intl-([a-zA-Z]+)\//, "");
|
|
844
|
+
if (spotifyPlaylistRegex.test(query)) return resolver(QueryType.SPOTIFY_PLAYLIST, query);
|
|
845
|
+
if (spotifyAlbumRegex.test(query)) return resolver(QueryType.SPOTIFY_ALBUM, query);
|
|
846
|
+
if (spotifySongRegex.test(query)) return resolver(QueryType.SPOTIFY_SONG, query);
|
|
847
|
+
return resolver(fallbackSearchEngine, query);
|
|
848
|
+
} else if (DomainsMap.Vimeo.includes(url.host)) {
|
|
849
|
+
if (vimeoRegex.test(query)) return resolver(QueryType.VIMEO, query);
|
|
850
|
+
return resolver(fallbackSearchEngine, query);
|
|
851
|
+
} else if (DomainsMap.ReverbNation.includes(url.host)) {
|
|
852
|
+
if (reverbnationRegex.test(query)) return resolver(QueryType.REVERBNATION, query);
|
|
853
|
+
return resolver(fallbackSearchEngine, query);
|
|
854
|
+
} else if (DomainsMap.SoundCloud.includes(url.host)) {
|
|
855
|
+
if (soundcloudPlaylistRegex.test(query)) return resolver(QueryType.SOUNDCLOUD_PLAYLIST, query);
|
|
856
|
+
if (soundcloudTrackRegex.test(query)) return resolver(QueryType.SOUNDCLOUD_TRACK, query);
|
|
857
|
+
return resolver(fallbackSearchEngine, query);
|
|
858
|
+
} else if (DomainsMap.AppleMusic.includes(url.host)) {
|
|
859
|
+
if (appleMusicAlbumRegex.test(query)) return resolver(QueryType.APPLE_MUSIC_ALBUM, query);
|
|
860
|
+
if (appleMusicPlaylistRegex.test(query)) return resolver(QueryType.APPLE_MUSIC_PLAYLIST, query);
|
|
861
|
+
if (appleMusicSongRegex.test(query)) return resolver(QueryType.APPLE_MUSIC_SONG, query);
|
|
862
|
+
return resolver(fallbackSearchEngine, query);
|
|
863
|
+
} else {
|
|
864
|
+
return resolver(QueryType.ARBITRARY, query);
|
|
865
|
+
}
|
|
866
|
+
} catch {
|
|
867
|
+
return resolver(fallbackSearchEngine, query);
|
|
868
|
+
}
|
|
869
|
+
}
|
|
870
|
+
/**
|
|
871
|
+
* Parses vimeo id from url
|
|
872
|
+
* @param {string} query The query
|
|
873
|
+
* @returns {string}
|
|
874
|
+
*/
|
|
875
|
+
static getVimeoID(query) {
|
|
876
|
+
return _QueryResolver.resolve(query).type === QueryType.VIMEO ? query.split("/").filter(Boolean).pop() : null;
|
|
877
|
+
}
|
|
878
|
+
static validateId(q) {
|
|
879
|
+
return youtubeVideoIdRegex.test(q);
|
|
880
|
+
}
|
|
881
|
+
static validateURL(q) {
|
|
882
|
+
return youtubeVideoURLRegex.test(q);
|
|
883
|
+
}
|
|
715
884
|
};
|
|
716
|
-
|
|
717
|
-
|
|
718
|
-
QueueRepeatMode2[QueueRepeatMode2["TRACK"] = 1] = "TRACK";
|
|
719
|
-
QueueRepeatMode2[QueueRepeatMode2["QUEUE"] = 2] = "QUEUE";
|
|
720
|
-
QueueRepeatMode2[QueueRepeatMode2["AUTOPLAY"] = 3] = "AUTOPLAY";
|
|
721
|
-
return QueueRepeatMode2;
|
|
722
|
-
})(QueueRepeatMode || {});
|
|
885
|
+
__name(_QueryResolver, "QueryResolver");
|
|
886
|
+
var QueryResolver = _QueryResolver;
|
|
723
887
|
|
|
724
888
|
// src/fabric/SearchResult.ts
|
|
725
889
|
var _SearchResult = class _SearchResult {
|
|
@@ -1119,7 +1283,7 @@ var VALIDATE_QUEUE_CAP = /* @__PURE__ */ __name((queue, items) => {
|
|
|
1119
1283
|
if (queue.maxSize < 1 || queue.maxSize === Infinity) return;
|
|
1120
1284
|
const maxCap = queue.getCapacity();
|
|
1121
1285
|
if (maxCap < tracks.length) {
|
|
1122
|
-
throw
|
|
1286
|
+
throw new OutOfSpaceError("tracks queue", maxCap, tracks.length);
|
|
1123
1287
|
}
|
|
1124
1288
|
}, "VALIDATE_QUEUE_CAP");
|
|
1125
1289
|
|
|
@@ -1137,12 +1301,12 @@ function isErisProxy(client) {
|
|
|
1137
1301
|
return Reflect.get(client, DiscordPlayerClientSymbol) === "Eris";
|
|
1138
1302
|
}
|
|
1139
1303
|
__name(isErisProxy, "isErisProxy");
|
|
1140
|
-
function declareProperty(
|
|
1141
|
-
Reflect.set(
|
|
1304
|
+
function declareProperty(target, key, value) {
|
|
1305
|
+
Reflect.set(target, key, value);
|
|
1142
1306
|
}
|
|
1143
1307
|
__name(declareProperty, "declareProperty");
|
|
1144
|
-
function getProperty(
|
|
1145
|
-
return Reflect.get(
|
|
1308
|
+
function getProperty(target, key) {
|
|
1309
|
+
return Reflect.get(target, key);
|
|
1146
1310
|
}
|
|
1147
1311
|
__name(getProperty, "getProperty");
|
|
1148
1312
|
function createErisCompat(client) {
|
|
@@ -1151,16 +1315,16 @@ function createErisCompat(client) {
|
|
|
1151
1315
|
const eris = module2;
|
|
1152
1316
|
erisVoiceEventsHandler(client);
|
|
1153
1317
|
const erisProxy = new Proxy(client, {
|
|
1154
|
-
get(
|
|
1318
|
+
get(target, p) {
|
|
1155
1319
|
switch (p) {
|
|
1156
1320
|
case "users":
|
|
1157
|
-
return erisUsersProxy(
|
|
1321
|
+
return erisUsersProxy(target, eris);
|
|
1158
1322
|
case "guilds":
|
|
1159
|
-
return erisGuildsProxy(
|
|
1323
|
+
return erisGuildsProxy(target, eris);
|
|
1160
1324
|
case "channels":
|
|
1161
|
-
return erisChannelsProxy(
|
|
1325
|
+
return erisChannelsProxy(target, eris);
|
|
1162
1326
|
case "__dp_voiceStateUpdate_proxy":
|
|
1163
|
-
return (
|
|
1327
|
+
return (handler) => erisVoiceStateUpdateProxy(target, erisProxy, handler);
|
|
1164
1328
|
case "incrementMaxListeners":
|
|
1165
1329
|
return () => {
|
|
1166
1330
|
client.setMaxListeners(client.getMaxListeners() + 1);
|
|
@@ -1171,7 +1335,7 @@ function createErisCompat(client) {
|
|
|
1171
1335
|
client.setMaxListeners(listeners < 0 ? 1 : listeners);
|
|
1172
1336
|
};
|
|
1173
1337
|
default:
|
|
1174
|
-
return
|
|
1338
|
+
return target[p];
|
|
1175
1339
|
}
|
|
1176
1340
|
}
|
|
1177
1341
|
});
|
|
@@ -1179,7 +1343,7 @@ function createErisCompat(client) {
|
|
|
1179
1343
|
return erisProxy;
|
|
1180
1344
|
}
|
|
1181
1345
|
__name(createErisCompat, "createErisCompat");
|
|
1182
|
-
function erisVoiceStateUpdateProxy(client, proxy,
|
|
1346
|
+
function erisVoiceStateUpdateProxy(client, proxy, handler) {
|
|
1183
1347
|
client.on("voiceStateUpdate", (member, oldState) => {
|
|
1184
1348
|
try {
|
|
1185
1349
|
const proxiedOldState = {
|
|
@@ -1217,7 +1381,7 @@ function erisVoiceStateUpdateProxy(client, proxy, handler2) {
|
|
|
1217
1381
|
}
|
|
1218
1382
|
}
|
|
1219
1383
|
};
|
|
1220
|
-
return
|
|
1384
|
+
return handler(proxiedNewState, proxiedOldState);
|
|
1221
1385
|
} catch {
|
|
1222
1386
|
}
|
|
1223
1387
|
});
|
|
@@ -1258,7 +1422,7 @@ function erisVoiceEventsHandler(client) {
|
|
|
1258
1422
|
}
|
|
1259
1423
|
__name(erisVoiceEventsHandler, "erisVoiceEventsHandler");
|
|
1260
1424
|
function erisChannelsProxy(client, eris) {
|
|
1261
|
-
const
|
|
1425
|
+
const handler = {
|
|
1262
1426
|
client,
|
|
1263
1427
|
get cache() {
|
|
1264
1428
|
return {
|
|
@@ -1283,26 +1447,26 @@ function erisChannelsProxy(client, eris) {
|
|
|
1283
1447
|
return channel?.id;
|
|
1284
1448
|
}
|
|
1285
1449
|
};
|
|
1286
|
-
return
|
|
1450
|
+
return handler;
|
|
1287
1451
|
}
|
|
1288
1452
|
__name(erisChannelsProxy, "erisChannelsProxy");
|
|
1289
1453
|
function erisResolvedChannelProxy(channel, client) {
|
|
1290
1454
|
if (!channel) return;
|
|
1291
1455
|
return new Proxy(channel, {
|
|
1292
|
-
get(
|
|
1456
|
+
get(target, p) {
|
|
1293
1457
|
switch (p) {
|
|
1294
1458
|
case "guild":
|
|
1295
|
-
return erisVoiceAdapterProxy(
|
|
1459
|
+
return erisVoiceAdapterProxy(target.guild, client);
|
|
1296
1460
|
case "members":
|
|
1297
|
-
return
|
|
1461
|
+
return target.voiceMembers;
|
|
1298
1462
|
case "isVoiceBased":
|
|
1299
|
-
return () =>
|
|
1463
|
+
return () => target.type === import_v10.ChannelType.GuildVoice || target.type === import_v10.ChannelType.GuildStageVoice;
|
|
1300
1464
|
case "isVoice":
|
|
1301
|
-
return () =>
|
|
1465
|
+
return () => target.type === import_v10.ChannelType.GuildVoice;
|
|
1302
1466
|
case "isStage":
|
|
1303
|
-
return () =>
|
|
1467
|
+
return () => target.type === import_v10.ChannelType.GuildStageVoice;
|
|
1304
1468
|
default:
|
|
1305
|
-
return
|
|
1469
|
+
return target[p];
|
|
1306
1470
|
}
|
|
1307
1471
|
}
|
|
1308
1472
|
});
|
|
@@ -1311,11 +1475,11 @@ __name(erisResolvedChannelProxy, "erisResolvedChannelProxy");
|
|
|
1311
1475
|
function erisVoiceAdapterProxy(guild, client) {
|
|
1312
1476
|
if (!guild) return;
|
|
1313
1477
|
return new Proxy(guild, {
|
|
1314
|
-
get(
|
|
1478
|
+
get(target, p) {
|
|
1315
1479
|
if (p === "voiceAdapterCreator") {
|
|
1316
|
-
return erisVoiceAdapterCreator(
|
|
1480
|
+
return erisVoiceAdapterCreator(target, client);
|
|
1317
1481
|
}
|
|
1318
|
-
return
|
|
1482
|
+
return target[p];
|
|
1319
1483
|
}
|
|
1320
1484
|
});
|
|
1321
1485
|
}
|
|
@@ -1344,14 +1508,14 @@ function erisVoiceAdapterCreator(guild, client) {
|
|
|
1344
1508
|
__name(erisVoiceAdapterCreator, "erisVoiceAdapterCreator");
|
|
1345
1509
|
function erisGuildsProxy(client, eris) {
|
|
1346
1510
|
return new Proxy(client.guilds, {
|
|
1347
|
-
get(
|
|
1511
|
+
get(target, p) {
|
|
1348
1512
|
if (p === "cache") {
|
|
1349
|
-
return
|
|
1513
|
+
return target;
|
|
1350
1514
|
}
|
|
1351
1515
|
if (p === "resolve" || p === "resolveId") {
|
|
1352
1516
|
const resolver = /* @__PURE__ */ __name(function(resolvable) {
|
|
1353
1517
|
if (typeof resolvable === "string") {
|
|
1354
|
-
return
|
|
1518
|
+
return target.get(resolvable);
|
|
1355
1519
|
}
|
|
1356
1520
|
if (resolvable instanceof eris.Guild) {
|
|
1357
1521
|
return resolvable;
|
|
@@ -1368,21 +1532,21 @@ function erisGuildsProxy(client, eris) {
|
|
|
1368
1532
|
return guild?.id;
|
|
1369
1533
|
};
|
|
1370
1534
|
}
|
|
1371
|
-
return
|
|
1535
|
+
return target[p];
|
|
1372
1536
|
}
|
|
1373
1537
|
});
|
|
1374
1538
|
}
|
|
1375
1539
|
__name(erisGuildsProxy, "erisGuildsProxy");
|
|
1376
1540
|
function erisUsersProxy(client, eris) {
|
|
1377
1541
|
return new Proxy(client.users, {
|
|
1378
|
-
get(
|
|
1542
|
+
get(target, p) {
|
|
1379
1543
|
if (p === "cache") {
|
|
1380
|
-
return
|
|
1544
|
+
return target;
|
|
1381
1545
|
}
|
|
1382
1546
|
if (p === "resolve" || p === "resolveId") {
|
|
1383
1547
|
const resolver = /* @__PURE__ */ __name(function(resolvable) {
|
|
1384
1548
|
if (typeof resolvable === "string") {
|
|
1385
|
-
return
|
|
1549
|
+
return target.get(resolvable);
|
|
1386
1550
|
}
|
|
1387
1551
|
if (resolvable instanceof eris.User) {
|
|
1388
1552
|
return resolvable;
|
|
@@ -1399,7 +1563,7 @@ function erisUsersProxy(client, eris) {
|
|
|
1399
1563
|
return user?.id;
|
|
1400
1564
|
};
|
|
1401
1565
|
}
|
|
1402
|
-
return
|
|
1566
|
+
return target[p];
|
|
1403
1567
|
}
|
|
1404
1568
|
});
|
|
1405
1569
|
}
|
|
@@ -1526,21 +1690,21 @@ var _BaseExtractor = class _BaseExtractor {
|
|
|
1526
1690
|
* @param info The track to stream
|
|
1527
1691
|
*/
|
|
1528
1692
|
async stream(info) {
|
|
1529
|
-
throw
|
|
1693
|
+
throw new NotImplementedError(`${this.constructor.name}.stream()`);
|
|
1530
1694
|
}
|
|
1531
1695
|
/**
|
|
1532
1696
|
* Handle the given query
|
|
1533
1697
|
* @param query The query to handle
|
|
1534
1698
|
*/
|
|
1535
1699
|
async handle(query, context) {
|
|
1536
|
-
throw
|
|
1700
|
+
throw new NotImplementedError(`${this.constructor.name}.handle()`);
|
|
1537
1701
|
}
|
|
1538
1702
|
/**
|
|
1539
1703
|
* Get related tracks for the given track
|
|
1540
1704
|
* @param track The track source
|
|
1541
1705
|
*/
|
|
1542
1706
|
async getRelatedTracks(track, history) {
|
|
1543
|
-
throw
|
|
1707
|
+
throw new NotImplementedError(`${this.constructor.name}.getRelatedTracks()`);
|
|
1544
1708
|
}
|
|
1545
1709
|
/**
|
|
1546
1710
|
* A stream middleware to handle streams before passing it to the player
|
|
@@ -1672,7 +1836,7 @@ function useHooksContext(hookName, mainOnly = false) {
|
|
|
1672
1836
|
isFallback = true;
|
|
1673
1837
|
}
|
|
1674
1838
|
if (!player)
|
|
1675
|
-
throw
|
|
1839
|
+
throw new IllegalHookInvocationError(
|
|
1676
1840
|
"discord-player",
|
|
1677
1841
|
`Player context is not available, ${isFallback ? "did you forget to initialize the player with `new Player(client)`?" : "is it being called inside <Player>.context.provide()?"}`
|
|
1678
1842
|
);
|
|
@@ -1681,14 +1845,14 @@ function useHooksContext(hookName, mainOnly = false) {
|
|
|
1681
1845
|
if (!isFallback) {
|
|
1682
1846
|
context = useContext(player.context);
|
|
1683
1847
|
if (!context)
|
|
1684
|
-
throw
|
|
1848
|
+
throw new IllegalHookInvocationError(
|
|
1685
1849
|
hookName,
|
|
1686
1850
|
`${hookName} must be called inside a player context created by <Player>.context.provide()`
|
|
1687
1851
|
);
|
|
1688
1852
|
} else {
|
|
1689
1853
|
context = {
|
|
1690
1854
|
get guild() {
|
|
1691
|
-
throw
|
|
1855
|
+
throw new IllegalHookInvocationError(
|
|
1692
1856
|
hookName,
|
|
1693
1857
|
`${hookName} must be called with an explicit guild argument when not inside a player context`
|
|
1694
1858
|
);
|
|
@@ -1786,14 +1950,14 @@ function useTimeline(options) {
|
|
|
1786
1950
|
__name(useTimeline, "useTimeline");
|
|
1787
1951
|
|
|
1788
1952
|
// src/hooks/stream/onAfterCreateStream.ts
|
|
1789
|
-
function onAfterCreateStream(
|
|
1790
|
-
getGlobalRegistry().set("@[onAfterCreateStream]",
|
|
1953
|
+
function onAfterCreateStream(handler) {
|
|
1954
|
+
getGlobalRegistry().set("@[onAfterCreateStream]", handler);
|
|
1791
1955
|
}
|
|
1792
1956
|
__name(onAfterCreateStream, "onAfterCreateStream");
|
|
1793
1957
|
|
|
1794
1958
|
// src/hooks/stream/onBeforeCreateStream.ts
|
|
1795
|
-
function onBeforeCreateStream(
|
|
1796
|
-
getGlobalRegistry().set("@[onBeforeCreateStream]",
|
|
1959
|
+
function onBeforeCreateStream(handler) {
|
|
1960
|
+
getGlobalRegistry().set("@[onBeforeCreateStream]", handler);
|
|
1797
1961
|
}
|
|
1798
1962
|
__name(onBeforeCreateStream, "onBeforeCreateStream");
|
|
1799
1963
|
|
|
@@ -1886,7 +2050,6 @@ ${sample}
|
|
|
1886
2050
|
async register(_extractor, options) {
|
|
1887
2051
|
if (typeof _extractor.identifier !== "string" || this.store.has(_extractor.identifier)) return null;
|
|
1888
2052
|
const extractor = new _extractor(this, options);
|
|
1889
|
-
if (this.player.options.bridgeProvider) options.bridgeProvider ?? (options.bridgeProvider = this.player.options.bridgeProvider);
|
|
1890
2053
|
try {
|
|
1891
2054
|
this.store.set(_extractor.identifier, extractor);
|
|
1892
2055
|
if (this.player.hasDebugger) this.player.debug(`${_extractor.identifier} extractor loaded!`);
|
|
@@ -1992,7 +2155,7 @@ ${sample}
|
|
|
1992
2155
|
return result2;
|
|
1993
2156
|
});
|
|
1994
2157
|
if (!result?.result)
|
|
1995
|
-
throw
|
|
2158
|
+
throw new BridgeFailedError(
|
|
1996
2159
|
this.getExecutionId(),
|
|
1997
2160
|
result?.error?.stack || result?.error?.message || "No extractors available to bridge"
|
|
1998
2161
|
);
|
|
@@ -2006,9 +2169,9 @@ ${sample}
|
|
|
2006
2169
|
* @param targetExtractor The target extractor to bridge to
|
|
2007
2170
|
*/
|
|
2008
2171
|
async requestBridgeFrom(track, sourceExtractor, targetExtractor) {
|
|
2009
|
-
const
|
|
2010
|
-
if (!
|
|
2011
|
-
return
|
|
2172
|
+
const target = this.resolve(targetExtractor);
|
|
2173
|
+
if (!target) return null;
|
|
2174
|
+
return target.bridge(track, sourceExtractor);
|
|
2012
2175
|
}
|
|
2013
2176
|
/**
|
|
2014
2177
|
* Check if extractor is disabled
|
|
@@ -2045,7 +2208,7 @@ var import_utils7 = require("@discord-player/utils");
|
|
|
2045
2208
|
var import_discord3 = require("discord.js");
|
|
2046
2209
|
var import_utils6 = require("@discord-player/utils");
|
|
2047
2210
|
|
|
2048
|
-
// src/
|
|
2211
|
+
// src/stream/StreamDispatcher.ts
|
|
2049
2212
|
var import_discord_voip = require("discord-voip");
|
|
2050
2213
|
var import_utils4 = require("@discord-player/utils");
|
|
2051
2214
|
var import_equalizer = require("@discord-player/equalizer");
|
|
@@ -2317,7 +2480,7 @@ var _StreamDispatcher = class _StreamDispatcher extends import_utils4.EventEmitt
|
|
|
2317
2480
|
*/
|
|
2318
2481
|
async playStream(resource = this.audioResource) {
|
|
2319
2482
|
if (!resource) {
|
|
2320
|
-
throw
|
|
2483
|
+
throw new NoAudioResourceError();
|
|
2321
2484
|
}
|
|
2322
2485
|
if (resource.ended) {
|
|
2323
2486
|
return void this.emit("finish", resource);
|
|
@@ -2437,7 +2600,7 @@ var _GuildQueueHistory = class _GuildQueueHistory {
|
|
|
2437
2600
|
async next() {
|
|
2438
2601
|
const track = this.nextTrack;
|
|
2439
2602
|
if (!track) {
|
|
2440
|
-
throw
|
|
2603
|
+
throw new NoResultError("No next track in the queue");
|
|
2441
2604
|
}
|
|
2442
2605
|
this.queue.node.skip({
|
|
2443
2606
|
reason: "HISTORY_NEXT_TRACK" /* HistoryNext */,
|
|
@@ -2450,7 +2613,7 @@ var _GuildQueueHistory = class _GuildQueueHistory {
|
|
|
2450
2613
|
async previous(preserveCurrent = true) {
|
|
2451
2614
|
const track = this.tracks.dispatch();
|
|
2452
2615
|
if (!track) {
|
|
2453
|
-
throw
|
|
2616
|
+
throw new NoResultError("No previous track in the queue");
|
|
2454
2617
|
}
|
|
2455
2618
|
const current = this.currentTrack;
|
|
2456
2619
|
await this.queue.node.play(track, { queue: false });
|
|
@@ -2477,157 +2640,6 @@ var GuildQueueHistory = _GuildQueueHistory;
|
|
|
2477
2640
|
// src/queue/GuildQueuePlayerNode.ts
|
|
2478
2641
|
var import_discord_voip2 = require("discord-voip");
|
|
2479
2642
|
var import_stream = require("stream");
|
|
2480
|
-
|
|
2481
|
-
// src/utils/QueryResolver.ts
|
|
2482
|
-
var import_undici = require("undici");
|
|
2483
|
-
var spotifySongRegex = /^https?:\/\/(?:embed\.|open\.)(?:spotify\.com\/)(intl-([a-z]|[A-Z])+\/)?(?:track\/|\?uri=spotify:track:)((\w|-){22})(\?si=.+)?$/;
|
|
2484
|
-
var spotifyPlaylistRegex = /^https?:\/\/(?:embed\.|open\.)(?:spotify\.com\/)(intl-([a-z]|[A-Z])+\/)?(?:playlist\/|\?uri=spotify:playlist:)((\w|-){22})(\?si=.+)?$/;
|
|
2485
|
-
var spotifyAlbumRegex = /^https?:\/\/(?:embed\.|open\.)(?:spotify\.com\/)(intl-([a-z]|[A-Z])+\/)?(?:album\/|\?uri=spotify:album:)((\w|-){22})(\?si=.+)?$/;
|
|
2486
|
-
var vimeoRegex = /^(http|https)?:\/\/(www\.|player\.)?vimeo\.com\/(?:channels\/(?:\w+\/)?|groups\/([^/]*)\/videos\/|video\/|)(\d+)(?:|\/\?)$/;
|
|
2487
|
-
var reverbnationRegex = /^https:\/\/(www.)?reverbnation.com\/(.+)\/song\/(.+)$/;
|
|
2488
|
-
var attachmentRegex = /^https?:\/\/.+$/;
|
|
2489
|
-
var appleMusicSongRegex = /^https?:\/\/music\.apple\.com\/.+?\/(song|album)\/.+?(\/.+?\?i=|\/)([0-9]+)$/;
|
|
2490
|
-
var appleMusicPlaylistRegex = /^https?:\/\/music\.apple\.com\/.+?\/playlist\/.+\/pl\.(u-|pm-)?[a-zA-Z0-9]+$/;
|
|
2491
|
-
var appleMusicAlbumRegex = /^https?:\/\/music\.apple\.com\/.+?\/album\/.+\/([0-9]+)$/;
|
|
2492
|
-
var soundcloudTrackRegex = /^https?:\/\/(m.|www.)?soundcloud.com\/(\w|-)+\/(\w|-)+(.+)?$/;
|
|
2493
|
-
var soundcloudPlaylistRegex = /^https?:\/\/(m.|www.)?soundcloud.com\/(\w|-)+\/sets\/(\w|-)+(.+)?$/;
|
|
2494
|
-
var youtubePlaylistRegex = /^https?:\/\/(www.)?youtube.com\/playlist\?list=((PL|FL|UU|LL|RD|OL)[a-zA-Z0-9-_]{16,41})$/;
|
|
2495
|
-
var youtubeVideoURLRegex = /^((?:https?:)?\/\/)?((?:www|m)\.)?((?:youtube\.com|youtu.be))(\/(?:[\w-]+\?v=|embed\/|v\/)?)([\w-]+)(\S+)?$/;
|
|
2496
|
-
var youtubeVideoIdRegex = /^[a-zA-Z0-9-_]{11}$/;
|
|
2497
|
-
var DomainsMap = {
|
|
2498
|
-
YouTube: ["youtube.com", "youtu.be", "music.youtube.com", "gaming.youtube.com", "www.youtube.com", "m.youtube.com"],
|
|
2499
|
-
Spotify: ["open.spotify.com", "embed.spotify.com"],
|
|
2500
|
-
Vimeo: ["vimeo.com", "player.vimeo.com"],
|
|
2501
|
-
ReverbNation: ["reverbnation.com"],
|
|
2502
|
-
SoundCloud: ["soundcloud.com"],
|
|
2503
|
-
AppleMusic: ["music.apple.com"]
|
|
2504
|
-
};
|
|
2505
|
-
var redirectDomains = /* @__PURE__ */ new Set([
|
|
2506
|
-
/^https?:\/\/spotify.link\/[A-Za-z0-9]+$/,
|
|
2507
|
-
/^https:\/\/on\.soundcloud\.com\/[a-zA-Z1-9]{0,17}$/
|
|
2508
|
-
]);
|
|
2509
|
-
var _QueryResolver = class _QueryResolver {
|
|
2510
|
-
/**
|
|
2511
|
-
* Query resolver
|
|
2512
|
-
*/
|
|
2513
|
-
constructor() {
|
|
2514
|
-
}
|
|
2515
|
-
// eslint-disable-line @typescript-eslint/no-empty-function
|
|
2516
|
-
static get regex() {
|
|
2517
|
-
return {
|
|
2518
|
-
spotifyAlbumRegex,
|
|
2519
|
-
spotifyPlaylistRegex,
|
|
2520
|
-
spotifySongRegex,
|
|
2521
|
-
vimeoRegex,
|
|
2522
|
-
reverbnationRegex,
|
|
2523
|
-
attachmentRegex,
|
|
2524
|
-
appleMusicAlbumRegex,
|
|
2525
|
-
appleMusicPlaylistRegex,
|
|
2526
|
-
appleMusicSongRegex,
|
|
2527
|
-
soundcloudTrackRegex,
|
|
2528
|
-
soundcloudPlaylistRegex,
|
|
2529
|
-
youtubePlaylistRegex
|
|
2530
|
-
};
|
|
2531
|
-
}
|
|
2532
|
-
/**
|
|
2533
|
-
* Pre-resolve redirect urls
|
|
2534
|
-
*/
|
|
2535
|
-
static async preResolve(query, maxDepth = 5) {
|
|
2536
|
-
if (!TypeUtil.isString(query)) throw Exceptions.ERR_INVALID_ARG_TYPE(query, "string", typeof query);
|
|
2537
|
-
for (const domain of redirectDomains) {
|
|
2538
|
-
if (domain.test(query)) {
|
|
2539
|
-
try {
|
|
2540
|
-
const res = await (0, import_undici.fetch)(query, {
|
|
2541
|
-
method: "GET",
|
|
2542
|
-
redirect: "follow"
|
|
2543
|
-
});
|
|
2544
|
-
if (!res.ok) break;
|
|
2545
|
-
if (/^https?:\/\/spotify.app.link\/(.+)$/.test(res.url)) {
|
|
2546
|
-
const body = await res.text();
|
|
2547
|
-
const target2 = body.split("https://open.spotify.com/track/")[1].split("?si=")[0];
|
|
2548
|
-
if (!target2) break;
|
|
2549
|
-
return `https://open.spotify.com/track/${target2}`;
|
|
2550
|
-
}
|
|
2551
|
-
return maxDepth < 1 ? res.url : this.preResolve(res.url, maxDepth - 1);
|
|
2552
|
-
} catch {
|
|
2553
|
-
break;
|
|
2554
|
-
}
|
|
2555
|
-
}
|
|
2556
|
-
}
|
|
2557
|
-
return query;
|
|
2558
|
-
}
|
|
2559
|
-
/**
|
|
2560
|
-
* Resolves the given search query
|
|
2561
|
-
* @param {string} query The query
|
|
2562
|
-
*/
|
|
2563
|
-
static resolve(query, fallbackSearchEngine = QueryType.AUTO_SEARCH) {
|
|
2564
|
-
if (!TypeUtil.isString(query)) throw Exceptions.ERR_INVALID_ARG_TYPE(query, "string", typeof query);
|
|
2565
|
-
if (!query.length) throw Exceptions.ERR_INFO_REQUIRED("query", String(query));
|
|
2566
|
-
const resolver = /* @__PURE__ */ __name((type, query2) => ({ type, query: query2 }), "resolver");
|
|
2567
|
-
try {
|
|
2568
|
-
const url = new URL(query);
|
|
2569
|
-
if (DomainsMap.YouTube.includes(url.host)) {
|
|
2570
|
-
query = query.replace(/(m(usic)?|gaming)\./, "").trim();
|
|
2571
|
-
const playlistId = url.searchParams.get("list");
|
|
2572
|
-
const videoId = url.searchParams.get("v");
|
|
2573
|
-
if (playlistId) {
|
|
2574
|
-
if (videoId && playlistId.startsWith("RD"))
|
|
2575
|
-
return resolver(
|
|
2576
|
-
QueryType.YOUTUBE_PLAYLIST,
|
|
2577
|
-
`https://www.youtube.com/watch?v=${videoId}&list=${playlistId}`
|
|
2578
|
-
);
|
|
2579
|
-
return resolver(QueryType.YOUTUBE_PLAYLIST, `https://www.youtube.com/playlist?list=${playlistId}`);
|
|
2580
|
-
}
|
|
2581
|
-
if (_QueryResolver.validateId(query) || _QueryResolver.validateURL(query))
|
|
2582
|
-
return resolver(QueryType.YOUTUBE_VIDEO, query);
|
|
2583
|
-
return resolver(fallbackSearchEngine, query);
|
|
2584
|
-
} else if (DomainsMap.Spotify.includes(url.host)) {
|
|
2585
|
-
query = query.replace(/intl-([a-zA-Z]+)\//, "");
|
|
2586
|
-
if (spotifyPlaylistRegex.test(query)) return resolver(QueryType.SPOTIFY_PLAYLIST, query);
|
|
2587
|
-
if (spotifyAlbumRegex.test(query)) return resolver(QueryType.SPOTIFY_ALBUM, query);
|
|
2588
|
-
if (spotifySongRegex.test(query)) return resolver(QueryType.SPOTIFY_SONG, query);
|
|
2589
|
-
return resolver(fallbackSearchEngine, query);
|
|
2590
|
-
} else if (DomainsMap.Vimeo.includes(url.host)) {
|
|
2591
|
-
if (vimeoRegex.test(query)) return resolver(QueryType.VIMEO, query);
|
|
2592
|
-
return resolver(fallbackSearchEngine, query);
|
|
2593
|
-
} else if (DomainsMap.ReverbNation.includes(url.host)) {
|
|
2594
|
-
if (reverbnationRegex.test(query)) return resolver(QueryType.REVERBNATION, query);
|
|
2595
|
-
return resolver(fallbackSearchEngine, query);
|
|
2596
|
-
} else if (DomainsMap.SoundCloud.includes(url.host)) {
|
|
2597
|
-
if (soundcloudPlaylistRegex.test(query)) return resolver(QueryType.SOUNDCLOUD_PLAYLIST, query);
|
|
2598
|
-
if (soundcloudTrackRegex.test(query)) return resolver(QueryType.SOUNDCLOUD_TRACK, query);
|
|
2599
|
-
return resolver(fallbackSearchEngine, query);
|
|
2600
|
-
} else if (DomainsMap.AppleMusic.includes(url.host)) {
|
|
2601
|
-
if (appleMusicAlbumRegex.test(query)) return resolver(QueryType.APPLE_MUSIC_ALBUM, query);
|
|
2602
|
-
if (appleMusicPlaylistRegex.test(query)) return resolver(QueryType.APPLE_MUSIC_PLAYLIST, query);
|
|
2603
|
-
if (appleMusicSongRegex.test(query)) return resolver(QueryType.APPLE_MUSIC_SONG, query);
|
|
2604
|
-
return resolver(fallbackSearchEngine, query);
|
|
2605
|
-
} else {
|
|
2606
|
-
return resolver(QueryType.ARBITRARY, query);
|
|
2607
|
-
}
|
|
2608
|
-
} catch {
|
|
2609
|
-
return resolver(fallbackSearchEngine, query);
|
|
2610
|
-
}
|
|
2611
|
-
}
|
|
2612
|
-
/**
|
|
2613
|
-
* Parses vimeo id from url
|
|
2614
|
-
* @param {string} query The query
|
|
2615
|
-
* @returns {string}
|
|
2616
|
-
*/
|
|
2617
|
-
static getVimeoID(query) {
|
|
2618
|
-
return _QueryResolver.resolve(query).type === QueryType.VIMEO ? query.split("/").filter(Boolean).pop() : null;
|
|
2619
|
-
}
|
|
2620
|
-
static validateId(q) {
|
|
2621
|
-
return youtubeVideoIdRegex.test(q);
|
|
2622
|
-
}
|
|
2623
|
-
static validateURL(q) {
|
|
2624
|
-
return youtubeVideoURLRegex.test(q);
|
|
2625
|
-
}
|
|
2626
|
-
};
|
|
2627
|
-
__name(_QueryResolver, "QueryResolver");
|
|
2628
|
-
var QueryResolver = _QueryResolver;
|
|
2629
|
-
|
|
2630
|
-
// src/queue/GuildQueuePlayerNode.ts
|
|
2631
2643
|
var import_promises2 = require("timers/promises");
|
|
2632
2644
|
|
|
2633
2645
|
// src/utils/AsyncQueue.ts
|
|
@@ -2898,7 +2910,7 @@ var _GuildQueuePlayerNode = class _GuildQueuePlayerNode {
|
|
|
2898
2910
|
separator = "\u2503"
|
|
2899
2911
|
} = options || {};
|
|
2900
2912
|
if (isNaN(length) || length < 0 || !Number.isFinite(length)) {
|
|
2901
|
-
throw
|
|
2913
|
+
throw new OutOfRangeError("[PlayerProgressBarOptions.length]", String(length), "0", "Finite Number");
|
|
2902
2914
|
}
|
|
2903
2915
|
const index = Math.round(timestamp.current.value / timestamp.total.value * length);
|
|
2904
2916
|
if (index >= 1 && index <= length) {
|
|
@@ -2928,7 +2940,7 @@ var _GuildQueuePlayerNode = class _GuildQueuePlayerNode {
|
|
|
2928
2940
|
if (duration > this.totalDuration) {
|
|
2929
2941
|
return this.skip({
|
|
2930
2942
|
reason: "SEEK_OVER_THRESHOLD" /* SEEK_OVER_THRESHOLD */,
|
|
2931
|
-
description:
|
|
2943
|
+
description: new OutOfRangeError("[duration]", String(duration), "0", String(this.totalDuration)).message
|
|
2932
2944
|
});
|
|
2933
2945
|
}
|
|
2934
2946
|
if (duration < 0) duration = 0;
|
|
@@ -3062,8 +3074,7 @@ var _GuildQueuePlayerNode = class _GuildQueuePlayerNode {
|
|
|
3062
3074
|
* @param index The position to insert to, defaults to 0.
|
|
3063
3075
|
*/
|
|
3064
3076
|
insert(track, index = 0) {
|
|
3065
|
-
if (!(track instanceof Track))
|
|
3066
|
-
throw Exceptions.ERR_INVALID_ARG_TYPE("track value", "instance of Track", String(track));
|
|
3077
|
+
if (!(track instanceof Track)) throw new InvalidArgTypeError("track value", "instance of Track", String(track));
|
|
3067
3078
|
VALIDATE_QUEUE_CAP(this.queue, track);
|
|
3068
3079
|
this.queue.tracks.store.splice(index, 0, track);
|
|
3069
3080
|
if (!this.queue.options.noEmitInsert) this.queue.emit(GuildQueueEvent.AudioTrackAdd, this.queue, track);
|
|
@@ -3076,7 +3087,7 @@ var _GuildQueuePlayerNode = class _GuildQueuePlayerNode {
|
|
|
3076
3087
|
move(from, to) {
|
|
3077
3088
|
const removed = this.remove(from);
|
|
3078
3089
|
if (!removed) {
|
|
3079
|
-
throw
|
|
3090
|
+
throw new NoResultError("invalid track to move");
|
|
3080
3091
|
}
|
|
3081
3092
|
this.insert(removed, to);
|
|
3082
3093
|
}
|
|
@@ -3088,7 +3099,7 @@ var _GuildQueuePlayerNode = class _GuildQueuePlayerNode {
|
|
|
3088
3099
|
copy(from, to) {
|
|
3089
3100
|
const src = this.queue.tracks.at(this.getTrackPosition(from));
|
|
3090
3101
|
if (!src) {
|
|
3091
|
-
throw
|
|
3102
|
+
throw new NoResultError("invalid track to copy");
|
|
3092
3103
|
}
|
|
3093
3104
|
this.insert(src, to);
|
|
3094
3105
|
}
|
|
@@ -3099,9 +3110,9 @@ var _GuildQueuePlayerNode = class _GuildQueuePlayerNode {
|
|
|
3099
3110
|
*/
|
|
3100
3111
|
swap(first, second) {
|
|
3101
3112
|
const src = this.getTrackPosition(first);
|
|
3102
|
-
if (src < 0) throw
|
|
3113
|
+
if (src < 0) throw new NoResultError("invalid src track to swap");
|
|
3103
3114
|
const dest = this.getTrackPosition(second);
|
|
3104
|
-
if (dest < 0) throw
|
|
3115
|
+
if (dest < 0) throw new NoResultError("invalid dest track to swap");
|
|
3105
3116
|
const srcT = this.queue.tracks.store[src];
|
|
3106
3117
|
const destT = this.queue.tracks.store[dest];
|
|
3107
3118
|
this.queue.tracks.store[src] = destT;
|
|
@@ -3128,13 +3139,6 @@ var _GuildQueuePlayerNode = class _GuildQueuePlayerNode {
|
|
|
3128
3139
|
}
|
|
3129
3140
|
return true;
|
|
3130
3141
|
}
|
|
3131
|
-
/**
|
|
3132
|
-
* Play raw audio resource
|
|
3133
|
-
* @param resource The audio resource to play
|
|
3134
|
-
*/
|
|
3135
|
-
async playRaw(resource) {
|
|
3136
|
-
await this.queue.dispatcher?.playStream(resource);
|
|
3137
|
-
}
|
|
3138
3142
|
/**
|
|
3139
3143
|
* Play the given track
|
|
3140
3144
|
* @param res The track to play
|
|
@@ -3142,7 +3146,7 @@ var _GuildQueuePlayerNode = class _GuildQueuePlayerNode {
|
|
|
3142
3146
|
*/
|
|
3143
3147
|
async play(res, options) {
|
|
3144
3148
|
if (!this.queue.dispatcher?.voiceConnection) {
|
|
3145
|
-
throw
|
|
3149
|
+
throw new NoVoiceConnectionError();
|
|
3146
3150
|
}
|
|
3147
3151
|
if (this.queue.hasDebugger)
|
|
3148
3152
|
this.queue.debug(`Received play request from guild ${this.queue.guild.name} (ID: ${this.queue.guild.id})`);
|
|
@@ -3162,12 +3166,19 @@ var _GuildQueuePlayerNode = class _GuildQueuePlayerNode {
|
|
|
3162
3166
|
}
|
|
3163
3167
|
const track = res || this.queue.tracks.dispatch();
|
|
3164
3168
|
if (!track) {
|
|
3165
|
-
const error =
|
|
3169
|
+
const error = new NoResultError("Play request received but track was not provided");
|
|
3166
3170
|
this.queue.emit(GuildQueueEvent.Error, this.queue, error);
|
|
3167
3171
|
return;
|
|
3168
3172
|
}
|
|
3169
3173
|
if (this.queue.hasDebugger) this.queue.debug("Requested option requires to play the track, initializing...");
|
|
3170
3174
|
try {
|
|
3175
|
+
const assignedResource = track.resource;
|
|
3176
|
+
if (assignedResource) {
|
|
3177
|
+
if (this.queue.hasDebugger)
|
|
3178
|
+
this.queue.debug("Track has an audio resource assigned, player will now play the resource directly...");
|
|
3179
|
+
this.queue.setTransitioning(!!options.transitionMode);
|
|
3180
|
+
return __privateMethod(this, _GuildQueuePlayerNode_instances, performPlay_fn).call(this, assignedResource);
|
|
3181
|
+
}
|
|
3171
3182
|
if (this.queue.hasDebugger) this.queue.debug(`Initiating stream extraction process...`);
|
|
3172
3183
|
const src = track.raw?.source || track.source;
|
|
3173
3184
|
const qt = track.queryType || (src === "spotify" ? "spotifySong" : src === "apple_music" ? "appleMusicSong" : src);
|
|
@@ -3314,7 +3325,7 @@ _progress = new WeakMap();
|
|
|
3314
3325
|
_hasFFmpegOptimization = new WeakMap();
|
|
3315
3326
|
_GuildQueuePlayerNode_instances = new WeakSet();
|
|
3316
3327
|
throw_fn = /* @__PURE__ */ __name(function(track, error) {
|
|
3317
|
-
const streamDefinitelyFailedMyDearT_TPleaseTrustMeItsNotMyFault =
|
|
3328
|
+
const streamDefinitelyFailedMyDearT_TPleaseTrustMeItsNotMyFault = new NoResultError(`Could not extract stream for this track${error ? `
|
|
3318
3329
|
|
|
3319
3330
|
${error.stack || error}` : ""}`);
|
|
3320
3331
|
this.queue.emit(
|
|
@@ -3413,8 +3424,7 @@ createFFmpegStream_fn = /* @__PURE__ */ __name(function(stream, track, seek = 0,
|
|
|
3413
3424
|
const ffmpegStream = this.queue.filters.ffmpeg.createStream(stream, {
|
|
3414
3425
|
encoderArgs: this.queue.filters.ffmpeg.args,
|
|
3415
3426
|
seek: seek / 1e3,
|
|
3416
|
-
fmt: opus ? "opus" : "s16le"
|
|
3417
|
-
useLegacyFFmpeg: !!this.queue.player.options.useLegacyFFmpeg
|
|
3427
|
+
fmt: opus ? "opus" : "s16le"
|
|
3418
3428
|
}).on("error", (err) => {
|
|
3419
3429
|
const m = `${err}`.toLowerCase();
|
|
3420
3430
|
if (this.queue.hasDebugger)
|
|
@@ -3432,8 +3442,6 @@ var import_equalizer2 = require("@discord-player/equalizer");
|
|
|
3432
3442
|
|
|
3433
3443
|
// src/utils/FFmpegStream.ts
|
|
3434
3444
|
var import_ffmpeg = require("@discord-player/ffmpeg");
|
|
3435
|
-
var prism = __toESM(require("prism-media"));
|
|
3436
|
-
var getFFmpegProvider = /* @__PURE__ */ __name((legacy = false) => legacy ? prism.default?.FFmpeg || prism.FFmpeg : import_ffmpeg.FFmpeg, "getFFmpegProvider");
|
|
3437
3445
|
var resolveArgs = /* @__PURE__ */ __name((config) => {
|
|
3438
3446
|
return Object.entries(config).reduce((acc, [key, value]) => {
|
|
3439
3447
|
if (value == null) return acc;
|
|
@@ -3476,8 +3484,7 @@ function createFFmpegStream(stream, options) {
|
|
|
3476
3484
|
const args = typeof stream === "string" ? FFMPEG_ARGS_STRING(stream, options.fmt, options.cookies) : FFMPEG_ARGS_PIPED(options.fmt);
|
|
3477
3485
|
if (!Number.isNaN(options.seek)) args.unshift("-ss", String(options.seek));
|
|
3478
3486
|
if (Array.isArray(options.encoderArgs)) args.push(...options.encoderArgs);
|
|
3479
|
-
const
|
|
3480
|
-
const transcoder = new FFMPEG({ shell: false, args });
|
|
3487
|
+
const transcoder = new import_ffmpeg.FFmpeg({ shell: false, args });
|
|
3481
3488
|
transcoder.on("close", () => transcoder.destroy());
|
|
3482
3489
|
if (typeof stream !== "string") {
|
|
3483
3490
|
stream.on("error", () => transcoder.destroy());
|
|
@@ -3501,18 +3508,20 @@ var makeBands = /* @__PURE__ */ __name((arr) => {
|
|
|
3501
3508
|
}, "makeBands");
|
|
3502
3509
|
var EqualizerConfigurationPreset = Object.freeze({
|
|
3503
3510
|
Flat: makeBands([]),
|
|
3504
|
-
Classical: makeBands(
|
|
3505
|
-
|
|
3506
|
-
|
|
3507
|
-
|
|
3508
|
-
|
|
3509
|
-
|
|
3510
|
-
|
|
3511
|
-
|
|
3512
|
-
|
|
3513
|
-
|
|
3514
|
-
|
|
3515
|
-
|
|
3511
|
+
Classical: makeBands(
|
|
3512
|
+
[
|
|
3513
|
+
-111022e-20,
|
|
3514
|
+
-111022e-20,
|
|
3515
|
+
-111022e-20,
|
|
3516
|
+
-111022e-20,
|
|
3517
|
+
-111022e-20,
|
|
3518
|
+
-111022e-20,
|
|
3519
|
+
-7.2,
|
|
3520
|
+
-7.2,
|
|
3521
|
+
-7.2,
|
|
3522
|
+
-9.6
|
|
3523
|
+
]
|
|
3524
|
+
),
|
|
3516
3525
|
Club: makeBands([-111022e-20, -111022e-20, 8, 5.6, 5.6, 5.6, 3.2, -111022e-20, -111022e-20, -111022e-20]),
|
|
3517
3526
|
Dance: makeBands([9.6, 7.2, 2.4, -111022e-20, -111022e-20, -5.6, -7.2, -7.2, -111022e-20, -111022e-20]),
|
|
3518
3527
|
FullBass: makeBands([-8, 9.6, 9.6, 5.6, 1.6, -4, -8, -10.4, -11.2, -11.2]),
|
|
@@ -3521,31 +3530,35 @@ var EqualizerConfigurationPreset = Object.freeze({
|
|
|
3521
3530
|
Headphones: makeBands([4.8, 11.2, 5.6, -3.2, -2.4, 1.6, 4.8, 9.6, 12.8, 14.4]),
|
|
3522
3531
|
LargeHall: makeBands([10.4, 10.4, 5.6, 5.6, -111022e-20, -4.8, -4.8, -4.8, -111022e-20, -111022e-20]),
|
|
3523
3532
|
Live: makeBands([-4.8, -111022e-20, 4, 5.6, 5.6, 5.6, 4, 2.4, 2.4, 2.4]),
|
|
3524
|
-
Party: makeBands(
|
|
3525
|
-
|
|
3526
|
-
|
|
3527
|
-
|
|
3528
|
-
|
|
3529
|
-
|
|
3530
|
-
|
|
3531
|
-
|
|
3532
|
-
|
|
3533
|
-
|
|
3534
|
-
|
|
3535
|
-
|
|
3533
|
+
Party: makeBands(
|
|
3534
|
+
[
|
|
3535
|
+
7.2,
|
|
3536
|
+
7.2,
|
|
3537
|
+
-111022e-20,
|
|
3538
|
+
-111022e-20,
|
|
3539
|
+
-111022e-20,
|
|
3540
|
+
-111022e-20,
|
|
3541
|
+
-111022e-20,
|
|
3542
|
+
-111022e-20,
|
|
3543
|
+
7.2,
|
|
3544
|
+
7.2
|
|
3545
|
+
]
|
|
3546
|
+
),
|
|
3536
3547
|
Pop: makeBands([-1.6, 4.8, 7.2, 8, 5.6, -111022e-20, -2.4, -2.4, -1.6, -1.6]),
|
|
3537
|
-
Reggae: makeBands(
|
|
3538
|
-
|
|
3539
|
-
|
|
3540
|
-
|
|
3541
|
-
|
|
3542
|
-
|
|
3543
|
-
|
|
3544
|
-
|
|
3545
|
-
|
|
3546
|
-
|
|
3547
|
-
|
|
3548
|
-
|
|
3548
|
+
Reggae: makeBands(
|
|
3549
|
+
[
|
|
3550
|
+
-111022e-20,
|
|
3551
|
+
-111022e-20,
|
|
3552
|
+
-111022e-20,
|
|
3553
|
+
-5.6,
|
|
3554
|
+
-111022e-20,
|
|
3555
|
+
6.4,
|
|
3556
|
+
6.4,
|
|
3557
|
+
-111022e-20,
|
|
3558
|
+
-111022e-20,
|
|
3559
|
+
-111022e-20
|
|
3560
|
+
]
|
|
3561
|
+
),
|
|
3549
3562
|
Rock: makeBands([8, 4.8, -5.6, -8, -3.2, 4, 8.8, 11.2, 11.2, 11.2]),
|
|
3550
3563
|
Ska: makeBands([-2.4, -4.8, -4, -111022e-20, 4, 5.6, 8.8, 9.6, 11.2, 9.6]),
|
|
3551
3564
|
Soft: makeBands([4.8, 1.6, -111022e-20, -2.4, -111022e-20, 4, 8, 9.6, 11.2, 12]),
|
|
@@ -3571,7 +3584,7 @@ var _FFmpegFilterer = class _FFmpegFilterer {
|
|
|
3571
3584
|
*/
|
|
3572
3585
|
setInputArgs(args) {
|
|
3573
3586
|
if (!args.every((arg) => typeof arg === "string"))
|
|
3574
|
-
throw
|
|
3587
|
+
throw new InvalidArgTypeError("args", "Array<string>", "invalid item(s)");
|
|
3575
3588
|
__privateSet(this, _inputArgs, args);
|
|
3576
3589
|
}
|
|
3577
3590
|
/**
|
|
@@ -3869,7 +3882,7 @@ var _GuildQueueStatistics = class _GuildQueueStatistics {
|
|
|
3869
3882
|
memoryUsage: process.memoryUsage(),
|
|
3870
3883
|
versions: {
|
|
3871
3884
|
node: process.version,
|
|
3872
|
-
player:
|
|
3885
|
+
player: this.queue.player.version
|
|
3873
3886
|
}
|
|
3874
3887
|
};
|
|
3875
3888
|
}
|
|
@@ -3896,7 +3909,7 @@ var _SyncedLyricsProvider = class _SyncedLyricsProvider {
|
|
|
3896
3909
|
return __privateGet(this, _callback) !== null;
|
|
3897
3910
|
}
|
|
3898
3911
|
load(lyrics) {
|
|
3899
|
-
if (!lyrics) throw
|
|
3912
|
+
if (!lyrics) throw new NotExistingError("syncedLyrics");
|
|
3900
3913
|
this.lyrics.clear();
|
|
3901
3914
|
this.unsubscribe();
|
|
3902
3915
|
const lines = lyrics.split("\n");
|
|
@@ -4129,6 +4142,24 @@ var TrackSkipReason = /* @__PURE__ */ ((TrackSkipReason2) => {
|
|
|
4129
4142
|
TrackSkipReason2["HistoryNext"] = "HISTORY_NEXT_TRACK";
|
|
4130
4143
|
return TrackSkipReason2;
|
|
4131
4144
|
})(TrackSkipReason || {});
|
|
4145
|
+
var QueueRepeatMode = {
|
|
4146
|
+
/**
|
|
4147
|
+
* Disable repeat mode.
|
|
4148
|
+
*/
|
|
4149
|
+
OFF: 0,
|
|
4150
|
+
/**
|
|
4151
|
+
* Repeat the current track.
|
|
4152
|
+
*/
|
|
4153
|
+
TRACK: 1,
|
|
4154
|
+
/**
|
|
4155
|
+
* Repeat the entire queue.
|
|
4156
|
+
*/
|
|
4157
|
+
QUEUE: 2,
|
|
4158
|
+
/**
|
|
4159
|
+
* When last track ends, play similar tracks in the future if queue is empty.
|
|
4160
|
+
*/
|
|
4161
|
+
AUTOPLAY: 3
|
|
4162
|
+
};
|
|
4132
4163
|
var _transitioning, _deleted, _shuffle, _GuildQueue_instances, attachListeners_fn, removeListeners_fn, performStart_fn, getNextTrack_fn, performFinish_fn, emitEnd_fn, handleAutoplay_fn;
|
|
4133
4164
|
var _GuildQueue = class _GuildQueue {
|
|
4134
4165
|
constructor(player, options) {
|
|
@@ -4149,7 +4180,7 @@ var _GuildQueue = class _GuildQueue {
|
|
|
4149
4180
|
stream,
|
|
4150
4181
|
type: import_discord_voip3.StreamType.Raw
|
|
4151
4182
|
}), "onAfterCreateStream"));
|
|
4152
|
-
__publicField(this, "repeatMode",
|
|
4183
|
+
__publicField(this, "repeatMode", QueueRepeatMode.OFF);
|
|
4153
4184
|
__publicField(this, "timeouts", new import_utils6.Collection());
|
|
4154
4185
|
__publicField(this, "stats", new GuildQueueStatistics(this));
|
|
4155
4186
|
__publicField(this, "tasksQueue", new AsyncQueue());
|
|
@@ -4178,10 +4209,10 @@ var _GuildQueue = class _GuildQueue {
|
|
|
4178
4209
|
this.filters.ffmpeg.setDefaults(this.options.ffmpegFilters);
|
|
4179
4210
|
}
|
|
4180
4211
|
if (!TypeUtil.isNumber(options.maxSize)) {
|
|
4181
|
-
throw
|
|
4212
|
+
throw new InvalidArgTypeError("[GuildNodeInit.maxSize]", "number", typeof options.maxSize);
|
|
4182
4213
|
}
|
|
4183
4214
|
if (!TypeUtil.isNumber(options.maxHistorySize)) {
|
|
4184
|
-
throw
|
|
4215
|
+
throw new InvalidArgTypeError("[GuildNodeInit.maxHistorySize]", "number", typeof options.maxHistorySize);
|
|
4185
4216
|
}
|
|
4186
4217
|
if (options.maxSize < 1) options.maxSize = Infinity;
|
|
4187
4218
|
if (options.maxHistorySize < 1) options.maxHistorySize = Infinity;
|
|
@@ -4348,7 +4379,7 @@ var _GuildQueue = class _GuildQueue {
|
|
|
4348
4379
|
*/
|
|
4349
4380
|
setMaxHistorySize(size) {
|
|
4350
4381
|
if (!TypeUtil.isNumber(size)) {
|
|
4351
|
-
throw
|
|
4382
|
+
throw new InvalidArgTypeError("size", "number", typeof size);
|
|
4352
4383
|
}
|
|
4353
4384
|
if (size < 1) size = Infinity;
|
|
4354
4385
|
this.options.maxHistorySize = size;
|
|
@@ -4359,7 +4390,7 @@ var _GuildQueue = class _GuildQueue {
|
|
|
4359
4390
|
*/
|
|
4360
4391
|
setMaxSize(size) {
|
|
4361
4392
|
if (!TypeUtil.isNumber(size)) {
|
|
4362
|
-
throw
|
|
4393
|
+
throw new InvalidArgTypeError("size", "number", typeof size);
|
|
4363
4394
|
}
|
|
4364
4395
|
if (size < 1) size = Infinity;
|
|
4365
4396
|
this.options.maxSize = size;
|
|
@@ -4457,12 +4488,12 @@ var _GuildQueue = class _GuildQueue {
|
|
|
4457
4488
|
*/
|
|
4458
4489
|
createDispatcher(connection, options = {}) {
|
|
4459
4490
|
if (connection.state.status === import_discord_voip3.VoiceConnectionStatus.Destroyed) {
|
|
4460
|
-
throw
|
|
4491
|
+
throw new VoiceConnectionDestroyedError();
|
|
4461
4492
|
}
|
|
4462
4493
|
const channel = this.player.client.channels.cache.get(connection.joinConfig.channelId);
|
|
4463
|
-
if (!channel) throw
|
|
4494
|
+
if (!channel) throw new NoVoiceChannelError();
|
|
4464
4495
|
if (!channel.isVoiceBased())
|
|
4465
|
-
throw
|
|
4496
|
+
throw new InvalidArgTypeError(
|
|
4466
4497
|
"channel",
|
|
4467
4498
|
`VoiceBasedChannel (type ${import_discord3.ChannelType.GuildVoice}/${import_discord3.ChannelType.GuildStageVoice})`,
|
|
4468
4499
|
String(channel?.type)
|
|
@@ -4488,7 +4519,7 @@ var _GuildQueue = class _GuildQueue {
|
|
|
4488
4519
|
async connect(channelResolvable, options = {}) {
|
|
4489
4520
|
const channel = this.player.client.channels.resolve(channelResolvable);
|
|
4490
4521
|
if (!channel || !channel.isVoiceBased()) {
|
|
4491
|
-
throw
|
|
4522
|
+
throw new InvalidArgTypeError(
|
|
4492
4523
|
"channel",
|
|
4493
4524
|
`VoiceBasedChannel (type ${import_discord3.ChannelType.GuildVoice}/${import_discord3.ChannelType.GuildStageVoice})`,
|
|
4494
4525
|
String(channel?.type)
|
|
@@ -4611,7 +4642,7 @@ var _GuildQueue = class _GuildQueue {
|
|
|
4611
4642
|
* @param options Player node initialization options
|
|
4612
4643
|
*/
|
|
4613
4644
|
async play(track, options) {
|
|
4614
|
-
if (!this.channel) throw
|
|
4645
|
+
if (!this.channel) throw new NoVoiceConnectionError();
|
|
4615
4646
|
return this.player.play(this.channel, track, options);
|
|
4616
4647
|
}
|
|
4617
4648
|
/**
|
|
@@ -4664,8 +4695,8 @@ attachListeners_fn = /* @__PURE__ */ __name(function(dispatcher) {
|
|
|
4664
4695
|
this.filters._lastFiltersCache.volume = f;
|
|
4665
4696
|
});
|
|
4666
4697
|
}, "#attachListeners");
|
|
4667
|
-
removeListeners_fn = /* @__PURE__ */ __name(function(
|
|
4668
|
-
|
|
4698
|
+
removeListeners_fn = /* @__PURE__ */ __name(function(target) {
|
|
4699
|
+
target.removeAllListeners();
|
|
4669
4700
|
}, "#removeListeners");
|
|
4670
4701
|
performStart_fn = /* @__PURE__ */ __name(function(resource) {
|
|
4671
4702
|
const track = resource?.metadata || this.currentTrack;
|
|
@@ -4713,24 +4744,24 @@ performFinish_fn = /* @__PURE__ */ __name(function(resource) {
|
|
|
4713
4744
|
this.emit(GuildQueueEvent.PlayerFinish, this, track);
|
|
4714
4745
|
}
|
|
4715
4746
|
if (__privateGet(this, _deleted)) return __privateMethod(this, _GuildQueue_instances, emitEnd_fn).call(this);
|
|
4716
|
-
if (this.tracks.size < 1 && this.repeatMode ===
|
|
4747
|
+
if (this.tracks.size < 1 && this.repeatMode === QueueRepeatMode.OFF) {
|
|
4717
4748
|
if (this.hasDebugger)
|
|
4718
4749
|
this.debug("No more tracks left in the queue to play and repeat mode is off, initiating #emitEnd()");
|
|
4719
4750
|
__privateMethod(this, _GuildQueue_instances, emitEnd_fn).call(this);
|
|
4720
4751
|
} else {
|
|
4721
|
-
if (this.repeatMode ===
|
|
4752
|
+
if (this.repeatMode === QueueRepeatMode.TRACK) {
|
|
4722
4753
|
if (this.hasDebugger) this.debug("Repeat mode is set to track, repeating last track from the history...");
|
|
4723
4754
|
this.__current = this.history.tracks.dispatch() || track;
|
|
4724
4755
|
return this.node.play(this.__current, { queue: false });
|
|
4725
4756
|
}
|
|
4726
|
-
if (this.repeatMode ===
|
|
4757
|
+
if (this.repeatMode === QueueRepeatMode.QUEUE) {
|
|
4727
4758
|
if (this.hasDebugger)
|
|
4728
4759
|
this.debug("Repeat mode is set to queue, moving last track from the history to current queue...");
|
|
4729
4760
|
const next = this.history.tracks.dispatch() || track;
|
|
4730
4761
|
if (next) this.tracks.add(next);
|
|
4731
4762
|
}
|
|
4732
4763
|
if (!this.tracks.size && track) {
|
|
4733
|
-
if (this.repeatMode ===
|
|
4764
|
+
if (this.repeatMode === QueueRepeatMode.AUTOPLAY) {
|
|
4734
4765
|
if (this.hasDebugger) this.debug("Repeat mode is set to autoplay, initiating autoplay handler...");
|
|
4735
4766
|
__privateMethod(this, _GuildQueue_instances, handleAutoplay_fn).call(this, track);
|
|
4736
4767
|
return;
|
|
@@ -4813,7 +4844,7 @@ var _GuildNodeManager = class _GuildNodeManager {
|
|
|
4813
4844
|
create(guild, options = {}) {
|
|
4814
4845
|
const server = this.player.client.guilds.resolve(guild);
|
|
4815
4846
|
if (!server) {
|
|
4816
|
-
throw
|
|
4847
|
+
throw new NoGuildError("Invalid or unknown guild");
|
|
4817
4848
|
}
|
|
4818
4849
|
if (this.cache.has(server.id)) {
|
|
4819
4850
|
return this.cache.get(server.id);
|
|
@@ -4911,7 +4942,7 @@ var _GuildNodeManager = class _GuildNodeManager {
|
|
|
4911
4942
|
delete(node) {
|
|
4912
4943
|
const queue = this.resolve(node);
|
|
4913
4944
|
if (!queue) {
|
|
4914
|
-
throw
|
|
4945
|
+
throw new NoGuildQueueError("Cannot delete non-existing queue");
|
|
4915
4946
|
}
|
|
4916
4947
|
queue.setTransitioning(true);
|
|
4917
4948
|
queue.node.stop(true);
|
|
@@ -5098,7 +5129,7 @@ var _LrcLib = class _LrcLib {
|
|
|
5098
5129
|
*/
|
|
5099
5130
|
search(params) {
|
|
5100
5131
|
if (!params.q && !params.trackName) {
|
|
5101
|
-
throw
|
|
5132
|
+
throw new InvalidArgTypeError(
|
|
5102
5133
|
"one of q or trackName",
|
|
5103
5134
|
"string",
|
|
5104
5135
|
[String(params.q), String(params.trackName)].join(", ")
|
|
@@ -5113,18 +5144,13 @@ var _LrcLib = class _LrcLib {
|
|
|
5113
5144
|
* @param options The request options
|
|
5114
5145
|
*/
|
|
5115
5146
|
async request(path, options) {
|
|
5116
|
-
let timeout = null;
|
|
5117
5147
|
const dispatcher = /* @__PURE__ */ __name(() => {
|
|
5118
|
-
const controller = new AbortController();
|
|
5119
|
-
timeout = setTimeout(() => {
|
|
5120
|
-
controller.abort();
|
|
5121
|
-
}, this.timeout).unref();
|
|
5122
5148
|
const { name, version: version2 } = Util.getRuntime();
|
|
5123
5149
|
const runtimeVersion = name === "unknown" ? version2 : `${name}/${version2}`;
|
|
5124
5150
|
const init = {
|
|
5125
5151
|
method: "GET",
|
|
5126
5152
|
redirect: "follow",
|
|
5127
|
-
signal:
|
|
5153
|
+
signal: AbortSignal.timeout(this.timeout),
|
|
5128
5154
|
...options,
|
|
5129
5155
|
headers: {
|
|
5130
5156
|
"User-Agent": `Discord-Player/${this.player.version} ${runtimeVersion ?? ""}`.trimEnd(),
|
|
@@ -5136,14 +5162,13 @@ var _LrcLib = class _LrcLib {
|
|
|
5136
5162
|
return fetch(`${this.api}${path.startsWith("/") ? path : "/" + path}`, init);
|
|
5137
5163
|
}, "dispatcher");
|
|
5138
5164
|
const res = await this.bucket.enqueue(dispatcher);
|
|
5139
|
-
if (timeout) clearTimeout(timeout);
|
|
5140
5165
|
return res.json();
|
|
5141
5166
|
}
|
|
5142
5167
|
};
|
|
5143
5168
|
__name(_LrcLib, "LrcLib");
|
|
5144
5169
|
var LrcLib = _LrcLib;
|
|
5145
5170
|
|
|
5146
|
-
// src/
|
|
5171
|
+
// src/stream/VoiceUtils.ts
|
|
5147
5172
|
var import_discord_voip4 = require("discord-voip");
|
|
5148
5173
|
var import_utils8 = require("@discord-player/utils");
|
|
5149
5174
|
var _VoiceUtils = class _VoiceUtils {
|
|
@@ -5167,7 +5192,7 @@ var _VoiceUtils = class _VoiceUtils {
|
|
|
5167
5192
|
* @returns {Promise<StreamDispatcher>}
|
|
5168
5193
|
*/
|
|
5169
5194
|
async connect(channel, options) {
|
|
5170
|
-
if (!options?.queue) throw
|
|
5195
|
+
if (!options?.queue) throw new NoGuildQueueError();
|
|
5171
5196
|
const conn = await this.join(channel, options);
|
|
5172
5197
|
const sub = new StreamDispatcher(conn, channel, options.queue, options.maxTime, options.audioPlayer);
|
|
5173
5198
|
return sub;
|
|
@@ -5298,9 +5323,60 @@ var import_discord_voip5 = require("discord-voip");
|
|
|
5298
5323
|
|
|
5299
5324
|
// src/DefaultVoiceStateHandler.ts
|
|
5300
5325
|
var import_discord4 = require("discord.js");
|
|
5326
|
+
function handleEmptyChannel(player, queue, guildId) {
|
|
5327
|
+
const timeout = setTimeout(() => {
|
|
5328
|
+
if (!Util.isVoiceEmpty(queue.channel) || !player.nodes.has(queue.guild.id)) return;
|
|
5329
|
+
if (queue.options.leaveOnEmpty) queue.delete();
|
|
5330
|
+
player.events.emit(GuildQueueEvent.EmptyChannel, queue);
|
|
5331
|
+
}, queue.options.leaveOnEmptyCooldown || 0).unref();
|
|
5332
|
+
queue.timeouts.set(`empty_${guildId}`, timeout);
|
|
5333
|
+
}
|
|
5334
|
+
__name(handleEmptyChannel, "handleEmptyChannel");
|
|
5335
|
+
function handleChannelPopulate(player, queue, guildId) {
|
|
5336
|
+
const emptyTimeout = queue.timeouts.get(`empty_${guildId}`);
|
|
5337
|
+
if (!Util.isVoiceEmpty(queue.channel) && emptyTimeout) {
|
|
5338
|
+
clearTimeout(emptyTimeout);
|
|
5339
|
+
queue.timeouts.delete(`empty_${guildId}`);
|
|
5340
|
+
player.events.emit(GuildQueueEvent.ChannelPopulate, queue);
|
|
5341
|
+
}
|
|
5342
|
+
}
|
|
5343
|
+
__name(handleChannelPopulate, "handleChannelPopulate");
|
|
5344
|
+
function handlePauseOnEmpty(queue) {
|
|
5345
|
+
const isEmpty = Util.isVoiceEmpty(queue.channel);
|
|
5346
|
+
const wasPausedOnEmpty = Reflect.get(queue, "__pausedOnEmpty");
|
|
5347
|
+
if (isEmpty && !wasPausedOnEmpty) {
|
|
5348
|
+
queue.node.setPaused(true);
|
|
5349
|
+
Reflect.set(queue, "__pausedOnEmpty", true);
|
|
5350
|
+
if (queue.hasDebugger) {
|
|
5351
|
+
queue.debug("Voice channel is empty and options#pauseOnEmpty is true, pausing...");
|
|
5352
|
+
}
|
|
5353
|
+
} else if (!isEmpty && wasPausedOnEmpty) {
|
|
5354
|
+
queue.node.setPaused(false);
|
|
5355
|
+
Reflect.set(queue, "__pausedOnEmpty", false);
|
|
5356
|
+
if (queue.hasDebugger) {
|
|
5357
|
+
queue.debug("Voice channel is not empty and options#pauseOnEmpty is true, resuming...");
|
|
5358
|
+
}
|
|
5359
|
+
}
|
|
5360
|
+
}
|
|
5361
|
+
__name(handlePauseOnEmpty, "handlePauseOnEmpty");
|
|
5362
|
+
function handleBotVoiceStateUpdate(queue, oldState, newState) {
|
|
5363
|
+
if (newState.serverMute != null && oldState.serverMute !== newState.serverMute) {
|
|
5364
|
+
queue.node.setPaused(newState.serverMute);
|
|
5365
|
+
return;
|
|
5366
|
+
}
|
|
5367
|
+
if (newState.channel?.type === import_discord4.ChannelType.GuildStageVoice && newState.suppress != null && oldState.suppress !== newState.suppress) {
|
|
5368
|
+
queue.node.setPaused(newState.suppress);
|
|
5369
|
+
if (newState.suppress) {
|
|
5370
|
+
newState.guild.members.me?.voice.setRequestToSpeak(true).catch(Util.noop);
|
|
5371
|
+
}
|
|
5372
|
+
}
|
|
5373
|
+
}
|
|
5374
|
+
__name(handleBotVoiceStateUpdate, "handleBotVoiceStateUpdate");
|
|
5301
5375
|
async function defaultVoiceStateHandler(player, queue, oldState, newState) {
|
|
5302
|
-
if (!queue
|
|
5303
|
-
|
|
5376
|
+
if (!queue?.connection || !queue.channel) return;
|
|
5377
|
+
const isBotState = newState.member?.id === newState.guild.members.me?.id;
|
|
5378
|
+
const guildId = oldState.guild.id;
|
|
5379
|
+
if (isBotState && oldState.channelId && !newState.channelId) {
|
|
5304
5380
|
try {
|
|
5305
5381
|
queue.delete();
|
|
5306
5382
|
} catch {
|
|
@@ -5308,91 +5384,21 @@ async function defaultVoiceStateHandler(player, queue, oldState, newState) {
|
|
|
5308
5384
|
return void player.events.emit(GuildQueueEvent.Disconnect, queue);
|
|
5309
5385
|
}
|
|
5310
5386
|
if (queue.options.pauseOnEmpty) {
|
|
5311
|
-
|
|
5312
|
-
if (isEmpty) {
|
|
5313
|
-
queue.node.setPaused(true);
|
|
5314
|
-
Reflect.set(queue, "__pausedOnEmpty", true);
|
|
5315
|
-
if (queue.hasDebugger) {
|
|
5316
|
-
queue.debug("Voice channel is empty and options#pauseOnEmpty is true, pausing...");
|
|
5317
|
-
}
|
|
5318
|
-
} else {
|
|
5319
|
-
if (Reflect.get(queue, "__pausedOnEmpty")) {
|
|
5320
|
-
queue.node.setPaused(false);
|
|
5321
|
-
Reflect.set(queue, "__pausedOnEmpty", false);
|
|
5322
|
-
if (queue.hasDebugger) {
|
|
5323
|
-
queue.debug("Voice channel is not empty and options#pauseOnEmpty is true, resuming...");
|
|
5324
|
-
}
|
|
5325
|
-
}
|
|
5326
|
-
}
|
|
5387
|
+
handlePauseOnEmpty(queue);
|
|
5327
5388
|
}
|
|
5328
|
-
if (
|
|
5329
|
-
if (
|
|
5330
|
-
|
|
5331
|
-
} else if (newState.channel?.type === import_discord4.ChannelType.GuildStageVoice && newState.suppress != null && oldState.suppress !== newState.suppress) {
|
|
5332
|
-
queue.node.setPaused(newState.suppress);
|
|
5333
|
-
if (newState.suppress) {
|
|
5334
|
-
newState.guild.members.me?.voice.setRequestToSpeak(true).catch(Util.noop);
|
|
5335
|
-
}
|
|
5336
|
-
}
|
|
5389
|
+
if (isBotState && newState.channelId && (!oldState.channelId || oldState.channelId !== newState.channelId)) {
|
|
5390
|
+
if (queue.connection) queue.channel = newState.channel;
|
|
5391
|
+
handleBotVoiceStateUpdate(queue, oldState, newState);
|
|
5337
5392
|
}
|
|
5338
5393
|
if (!newState.channelId && oldState.channelId === queue.channel.id) {
|
|
5339
5394
|
if (!Util.isVoiceEmpty(queue.channel)) return;
|
|
5340
|
-
|
|
5341
|
-
|
|
5342
|
-
|
|
5343
|
-
|
|
5344
|
-
|
|
5345
|
-
|
|
5346
|
-
|
|
5347
|
-
}
|
|
5348
|
-
if (newState.channelId && newState.channelId === queue.channel.id) {
|
|
5349
|
-
const emptyTimeout = queue.timeouts.get(`empty_${oldState.guild.id}`);
|
|
5350
|
-
const channelEmpty = Util.isVoiceEmpty(queue.channel);
|
|
5351
|
-
if (!channelEmpty && emptyTimeout) {
|
|
5352
|
-
clearTimeout(emptyTimeout);
|
|
5353
|
-
queue.timeouts.delete(`empty_${oldState.guild.id}`);
|
|
5354
|
-
player.events.emit(GuildQueueEvent.ChannelPopulate, queue);
|
|
5355
|
-
}
|
|
5356
|
-
}
|
|
5357
|
-
if (oldState.channelId && newState.channelId && oldState.channelId !== newState.channelId) {
|
|
5358
|
-
if (newState.member?.id === newState.guild.members.me?.id) {
|
|
5359
|
-
if (queue.connection && newState.member?.id === newState.guild.members.me?.id) queue.channel = newState.channel;
|
|
5360
|
-
const emptyTimeout = queue.timeouts.get(`empty_${oldState.guild.id}`);
|
|
5361
|
-
const channelEmpty = Util.isVoiceEmpty(queue.channel);
|
|
5362
|
-
if (!channelEmpty && emptyTimeout) {
|
|
5363
|
-
clearTimeout(emptyTimeout);
|
|
5364
|
-
queue.timeouts.delete(`empty_${oldState.guild.id}`);
|
|
5365
|
-
player.events.emit(GuildQueueEvent.ChannelPopulate, queue);
|
|
5366
|
-
} else {
|
|
5367
|
-
const timeout = setTimeout(() => {
|
|
5368
|
-
if (queue.connection && !Util.isVoiceEmpty(queue.channel)) return;
|
|
5369
|
-
if (!player.nodes.has(queue.guild.id)) return;
|
|
5370
|
-
if (queue.options.leaveOnEmpty) queue.delete();
|
|
5371
|
-
player.events.emit(GuildQueueEvent.EmptyChannel, queue);
|
|
5372
|
-
}, queue.options.leaveOnEmptyCooldown || 0).unref();
|
|
5373
|
-
queue.timeouts.set(`empty_${oldState.guild.id}`, timeout);
|
|
5374
|
-
}
|
|
5375
|
-
} else {
|
|
5376
|
-
if (newState.channelId !== queue.channel.id) {
|
|
5377
|
-
const channelEmpty = Util.isVoiceEmpty(queue.channel);
|
|
5378
|
-
if (!channelEmpty) return;
|
|
5379
|
-
if (queue.timeouts.has(`empty_${oldState.guild.id}`)) return;
|
|
5380
|
-
const timeout = setTimeout(() => {
|
|
5381
|
-
if (!Util.isVoiceEmpty(queue.channel)) return;
|
|
5382
|
-
if (!player.nodes.has(queue.guild.id)) return;
|
|
5383
|
-
if (queue.options.leaveOnEmpty) queue.delete();
|
|
5384
|
-
player.events.emit(GuildQueueEvent.EmptyChannel, queue);
|
|
5385
|
-
}, queue.options.leaveOnEmptyCooldown || 0).unref();
|
|
5386
|
-
queue.timeouts.set(`empty_${oldState.guild.id}`, timeout);
|
|
5387
|
-
} else {
|
|
5388
|
-
const emptyTimeout = queue.timeouts.get(`empty_${oldState.guild.id}`);
|
|
5389
|
-
const channelEmpty = Util.isVoiceEmpty(queue.channel);
|
|
5390
|
-
if (!channelEmpty && emptyTimeout) {
|
|
5391
|
-
clearTimeout(emptyTimeout);
|
|
5392
|
-
queue.timeouts.delete(`empty_${oldState.guild.id}`);
|
|
5393
|
-
player.events.emit(GuildQueueEvent.ChannelPopulate, queue);
|
|
5394
|
-
}
|
|
5395
|
-
}
|
|
5395
|
+
handleEmptyChannel(player, queue, guildId);
|
|
5396
|
+
} else if (newState.channelId === queue.channel.id) {
|
|
5397
|
+
handleChannelPopulate(player, queue, guildId);
|
|
5398
|
+
} else if (oldState.channelId !== newState.channelId) {
|
|
5399
|
+
if (newState.channelId !== queue.channel.id && !Util.isVoiceEmpty(queue.channel)) return;
|
|
5400
|
+
if (!queue.timeouts.has(`empty_${guildId}`)) {
|
|
5401
|
+
handleEmptyChannel(player, queue, guildId);
|
|
5396
5402
|
}
|
|
5397
5403
|
}
|
|
5398
5404
|
}
|
|
@@ -5401,6 +5407,14 @@ __name(defaultVoiceStateHandler, "defaultVoiceStateHandler");
|
|
|
5401
5407
|
// src/utils/DependencyReportGenerator.ts
|
|
5402
5408
|
var import_node_path = require("path");
|
|
5403
5409
|
var import_ffmpeg2 = require("@discord-player/ffmpeg");
|
|
5410
|
+
|
|
5411
|
+
// src/version.ts
|
|
5412
|
+
var version = (
|
|
5413
|
+
/* @__MACRO__ getVersion */
|
|
5414
|
+
"7.0.0"
|
|
5415
|
+
);
|
|
5416
|
+
|
|
5417
|
+
// src/utils/DependencyReportGenerator.ts
|
|
5404
5418
|
var DependencyReportGenerator = {
|
|
5405
5419
|
/**
|
|
5406
5420
|
* Finds the package.json file of a package.
|
|
@@ -5411,10 +5425,10 @@ var DependencyReportGenerator = {
|
|
|
5411
5425
|
*/
|
|
5412
5426
|
findPackageJSON(dir, packageName, depth) {
|
|
5413
5427
|
if (depth === 0) return null;
|
|
5414
|
-
const
|
|
5428
|
+
const target = (0, import_node_path.resolve)(dir, "package.json");
|
|
5415
5429
|
const next = /* @__PURE__ */ __name(() => DependencyReportGenerator.findPackageJSON((0, import_node_path.resolve)(dir, ".."), packageName, depth - 1), "next");
|
|
5416
5430
|
try {
|
|
5417
|
-
const pkgJSON = require(
|
|
5431
|
+
const pkgJSON = require(target);
|
|
5418
5432
|
if (pkgJSON.name !== packageName) {
|
|
5419
5433
|
return next();
|
|
5420
5434
|
}
|
|
@@ -5432,7 +5446,7 @@ var DependencyReportGenerator = {
|
|
|
5432
5446
|
version(name, maxLookupDepth = 3) {
|
|
5433
5447
|
try {
|
|
5434
5448
|
if (name === "discord-player") {
|
|
5435
|
-
return
|
|
5449
|
+
return version;
|
|
5436
5450
|
}
|
|
5437
5451
|
const pkg = DependencyReportGenerator.findPackageJSON((0, import_node_path.dirname)(require.resolve(name)), name, maxLookupDepth);
|
|
5438
5452
|
return pkg?.version ?? null;
|
|
@@ -5507,6 +5521,14 @@ var DependencyReportGenerator = {
|
|
|
5507
5521
|
};
|
|
5508
5522
|
|
|
5509
5523
|
// src/Player.ts
|
|
5524
|
+
var PlayerEvent = {
|
|
5525
|
+
debug: "debug",
|
|
5526
|
+
Debug: "debug",
|
|
5527
|
+
error: "error",
|
|
5528
|
+
Error: "error",
|
|
5529
|
+
voiceStateUpdate: "voiceStateUpdate",
|
|
5530
|
+
VoiceStateUpdate: "voiceStateUpdate"
|
|
5531
|
+
};
|
|
5510
5532
|
var _lastLatency, _voiceStateUpdateListener, _lagMonitorTimeout, _lagMonitorInterval, _onVoiceStateUpdate, _hooksCtx;
|
|
5511
5533
|
var _Player = class _Player extends PlayerEventsEmitter {
|
|
5512
5534
|
/**
|
|
@@ -5587,7 +5609,6 @@ var _Player = class _Player extends PlayerEventsEmitter {
|
|
|
5587
5609
|
connectionTimeout: 2e4,
|
|
5588
5610
|
lagMonitor: 3e4,
|
|
5589
5611
|
queryCache: options.queryCache === null ? null : options.queryCache || new QueryCache(this),
|
|
5590
|
-
useLegacyFFmpeg: false,
|
|
5591
5612
|
skipFFmpeg: true,
|
|
5592
5613
|
probeTimeout: 5e3,
|
|
5593
5614
|
overrideFallbackContext: true,
|
|
@@ -5640,8 +5661,8 @@ var _Player = class _Player extends PlayerEventsEmitter {
|
|
|
5640
5661
|
* Override default voice state update handler
|
|
5641
5662
|
* @param handler The handler callback
|
|
5642
5663
|
*/
|
|
5643
|
-
onVoiceStateUpdate(
|
|
5644
|
-
__privateSet(this, _onVoiceStateUpdate,
|
|
5664
|
+
onVoiceStateUpdate(handler) {
|
|
5665
|
+
__privateSet(this, _onVoiceStateUpdate, handler);
|
|
5645
5666
|
}
|
|
5646
5667
|
debug(m) {
|
|
5647
5668
|
return this.emit("debug", m);
|
|
@@ -5788,17 +5809,11 @@ var _Player = class _Player extends PlayerEventsEmitter {
|
|
|
5788
5809
|
async play(channel, query, options = {}) {
|
|
5789
5810
|
const vc = this.client.channels.resolve(channel);
|
|
5790
5811
|
if (!vc?.isVoiceBased())
|
|
5791
|
-
throw
|
|
5792
|
-
"channel",
|
|
5793
|
-
"VoiceBasedChannel",
|
|
5794
|
-
!vc ? "undefined" : `channel type ${vc.type}`
|
|
5795
|
-
);
|
|
5812
|
+
throw new InvalidArgTypeError("channel", "VoiceBasedChannel", !vc ? "undefined" : `channel type ${vc.type}`);
|
|
5796
5813
|
const originalResult = query instanceof SearchResult ? query : await this.search(query, options);
|
|
5797
5814
|
const result = await options.afterSearch?.(originalResult) || originalResult;
|
|
5798
5815
|
if (result.isEmpty()) {
|
|
5799
|
-
throw
|
|
5800
|
-
`No results found for "${query}" (Extractor: ${result.extractor?.identifier || "N/A"})`
|
|
5801
|
-
);
|
|
5816
|
+
throw new NoResultError(`No results found for "${query}" (Extractor: ${result.extractor?.identifier || "N/A"})`);
|
|
5802
5817
|
}
|
|
5803
5818
|
const queue = this.nodes.create(vc.guild, options.nodeOptions);
|
|
5804
5819
|
if (this.hasDebugger) this.debug(`[AsyncQueue] Acquiring an entry...`);
|
|
@@ -5840,6 +5855,9 @@ var _Player = class _Player extends PlayerEventsEmitter {
|
|
|
5840
5855
|
*/
|
|
5841
5856
|
async search(searchQuery, options = {}) {
|
|
5842
5857
|
if (searchQuery instanceof SearchResult) return searchQuery;
|
|
5858
|
+
if (searchQuery instanceof import_discord_voip5.AudioResource) {
|
|
5859
|
+
searchQuery = this.createTrackFromAudioResource(searchQuery);
|
|
5860
|
+
}
|
|
5843
5861
|
if (options.requestedBy != null) options.requestedBy = this.client.users.resolve(options.requestedBy);
|
|
5844
5862
|
options.blockExtractors ?? (options.blockExtractors = this.options.blockExtractors);
|
|
5845
5863
|
options.fallbackSearchEngine ?? (options.fallbackSearchEngine = QueryType.AUTO_SEARCH);
|
|
@@ -6022,7 +6040,6 @@ var _Player = class _Player extends PlayerEventsEmitter {
|
|
|
6022
6040
|
`- discord.js: ${import_discord5.version}`,
|
|
6023
6041
|
`- Node version: ${process.version} (Detected Runtime: ${runtime}, Platform: ${process.platform} [${process.arch}])`,
|
|
6024
6042
|
(() => {
|
|
6025
|
-
if (this.options.useLegacyFFmpeg) return "- ffmpeg: N/A (using legacy ffmpeg)";
|
|
6026
6043
|
const info = import_ffmpeg3.FFmpeg.resolveSafe();
|
|
6027
6044
|
if (!info) return "FFmpeg/Avconv not found";
|
|
6028
6045
|
return [
|
|
@@ -6053,6 +6070,37 @@ var _Player = class _Player extends PlayerEventsEmitter {
|
|
|
6053
6070
|
createPlaylist(data) {
|
|
6054
6071
|
return new Playlist(this, data);
|
|
6055
6072
|
}
|
|
6073
|
+
/**
|
|
6074
|
+
* Creates a track from an audio resource.
|
|
6075
|
+
* @param resource The audio resource
|
|
6076
|
+
*/
|
|
6077
|
+
createTrackFromAudioResource(resource) {
|
|
6078
|
+
const metadata = resource.metadata;
|
|
6079
|
+
const ref = import_discord5.SnowflakeUtil.generate().toString();
|
|
6080
|
+
const maybeTitle = "title" in metadata ? `${metadata.title}` : `Track ${ref}`;
|
|
6081
|
+
const maybeAuthor = "author" in metadata ? `${metadata.author}` : "Unknown author";
|
|
6082
|
+
const maybeDuration = "duration" in metadata ? `${metadata.duration}` : "00:00";
|
|
6083
|
+
const maybeThumbnail = "thumbnail" in metadata ? `${metadata.thumbnail}` : void 0;
|
|
6084
|
+
const maybeURL = "url" in metadata ? `${metadata.url}` : `discord-player://blob/${ref}`;
|
|
6085
|
+
const maybeDescription = "description" in metadata ? `${metadata.description}` : "No description available.";
|
|
6086
|
+
const maybeViews = "views" in metadata ? Number(metadata.views) || 0 : 0;
|
|
6087
|
+
const track = new Track(this, {
|
|
6088
|
+
title: maybeTitle,
|
|
6089
|
+
author: maybeAuthor,
|
|
6090
|
+
duration: maybeDuration,
|
|
6091
|
+
thumbnail: maybeThumbnail,
|
|
6092
|
+
url: maybeURL,
|
|
6093
|
+
description: maybeDescription,
|
|
6094
|
+
queryType: QueryType.DISCORD_PLAYER_BLOB,
|
|
6095
|
+
source: "arbitrary",
|
|
6096
|
+
metadata,
|
|
6097
|
+
live: false,
|
|
6098
|
+
views: maybeViews
|
|
6099
|
+
});
|
|
6100
|
+
resource.metadata = track;
|
|
6101
|
+
track.setResource(resource);
|
|
6102
|
+
return track;
|
|
6103
|
+
}
|
|
6056
6104
|
};
|
|
6057
6105
|
_lastLatency = new WeakMap();
|
|
6058
6106
|
_voiceStateUpdateListener = new WeakMap();
|
|
@@ -6064,13 +6112,12 @@ __name(_Player, "Player");
|
|
|
6064
6112
|
/**
|
|
6065
6113
|
* The version of discord-player
|
|
6066
6114
|
*/
|
|
6067
|
-
__publicField(_Player, "version",
|
|
6115
|
+
__publicField(_Player, "version", version);
|
|
6068
6116
|
var Player = _Player;
|
|
6069
6117
|
|
|
6070
6118
|
// src/index.ts
|
|
6071
6119
|
var import_equalizer3 = require("@discord-player/equalizer");
|
|
6072
6120
|
var import_discord_voip6 = require("discord-voip");
|
|
6073
|
-
var version = "7.0.0-dev.5";
|
|
6074
6121
|
// Annotate the CommonJS export names for ESM import in node:
|
|
6075
6122
|
0 && (module.exports = {
|
|
6076
6123
|
AF_NIGHTCORE_RATE,
|
|
@@ -6148,4 +6195,4 @@ var version = "7.0.0-dev.5";
|
|
|
6148
6195
|
version,
|
|
6149
6196
|
...require("@discord-player/ffmpeg")
|
|
6150
6197
|
});
|
|
6151
|
-
//# sourceMappingURL=data:application/json;base64,{
  "version": 3,
  "sources": ["../src/index.ts", "../src/compat/createErisCompat.ts", "../src/utils/Util.ts", "../src/fabric/Track.ts", "../src/utils/TypeUtil.ts", "../src/errors/index.ts", "../src/utils/serde.ts", "../src/fabric/Playlist.ts", "../src/types/types.ts", "../src/fabric/SearchResult.ts", "../src/utils/AudioFilters.ts", "../src/utils/PlayerEventsEmitter.ts", "../src/extractors/BaseExtractor.ts", "../src/extractors/ExtractorExecutionContext.ts", "../src/hooks/context/async-context.ts", "../src/utils/__internal__/_container.ts", "../src/utils/__internal__/getGlobalRegistry.ts", "../src/hooks/common.ts", "../src/hooks/useHistory.ts", "../src/hooks/usePlayer.ts", "../src/hooks/useQueue.ts", "../src/hooks/useMainPlayer.ts", "../src/hooks/useMetadata.ts", "../src/hooks/useTimeline.ts", "../src/hooks/stream/onAfterCreateStream.ts", "../src/hooks/stream/onBeforeCreateStream.ts", "../src/hooks/useVolume.ts", "../src/queue/GuildNodeManager.ts", "../src/queue/GuildQueue.ts", "../src/VoiceInterface/StreamDispatcher.ts", "../src/queue/GuildQueueHistory.ts", "../src/queue/GuildQueuePlayerNode.ts", "../src/utils/QueryResolver.ts", "../src/utils/AsyncQueue.ts", "../src/queue/GuildQueueAudioFilters.ts", "../src/utils/FFmpegStream.ts", "../src/queue/GuildQueueStatistics.ts", "../src/queue/SyncedLyricsProvider.ts", "../src/utils/SequentialBucket.ts", "../src/lrclib/LrcLib.ts", "../src/VoiceInterface/VoiceUtils.ts", "../src/utils/QueryCache.ts", "../src/Player.ts", "../src/DefaultVoiceStateHandler.ts", "../src/utils/DependencyReportGenerator.ts"],
  "sourcesContent": ["export { createErisCompat, isErisProxy } from './compat/createErisCompat';\nexport * from './utils/PlayerEventsEmitter';\nexport * from './utils/AudioFilters';\nexport * from './extractors/BaseExtractor';\nexport * from './extractors/ExtractorExecutionContext';\nexport * from './fabric';\nexport * from './queue';\nexport * from './lrclib/LrcLib';\nexport * from './utils/SequentialBucket';\nexport * from './VoiceInterface/VoiceUtils';\nexport * from './VoiceInterface/StreamDispatcher';\nexport * from './utils/Util';\nexport * from './utils/TypeUtil';\nexport * from './utils/AsyncQueue';\nexport * from './types/types';\nexport * from './utils/FFmpegStream';\nexport * from './utils/QueryCache';\nexport * from './utils/QueryResolver';\nexport * from '@discord-player/ffmpeg';\nexport * from './Player';\nexport * from './hooks';\nexport * from './utils/serde';\nexport * from './utils/DependencyReportGenerator';\nexport {\n  AudioFilters as PCMAudioFilters,\n  type BiquadFilters,\n  FilterType as BiquadFilterType,\n  type PCMFilters,\n  Q_BUTTERWORTH,\n  VolumeTransformer,\n  BASS_EQ_BANDS,\n  AF_NIGHTCORE_RATE,\n  AF_VAPORWAVE_RATE,\n  FiltersChain,\n} from '@discord-player/equalizer';\nexport {\n  createAudioPlayer,\n  AudioPlayer,\n  getVoiceConnection,\n  getVoiceConnections,\n  joinVoiceChannel,\n  type JoinConfig,\n  type JoinVoiceChannelOptions,\n  type CreateAudioPlayerOptions,\n} from 'discord-voip';\n\n// eslint-disable-next-line @typescript-eslint/no-inferrable-types\nexport const version: string = '7.0.0-dev.5';\n", "/* eslint-disable @typescript-eslint/no-explicit-any */\n// @ts-nocheck\n\nimport { ChannelType, GatewayDispatchEvents } from 'discord-api-types/v10';\nimport { Util } from '../utils/Util';\n\nimport type { DiscordGatewayAdapterCreator } from 'discord-voip';\nimport {\n  Client,\n  GatewayVoiceServerUpdateDispatchData,\n  GatewayVoiceStateUpdateDispatchData,\n  VoiceState,\n} from 'discord.js';\nimport type Eris from 'eris';\n\ntype ErisUserResolvable = Eris.User | string | Eris.Member;\ntype ErisGuildResolvable = Eris.Guild | string | Eris.Member | Eris.GuildChannel | Eris.Role;\ntype ErisChannelResolvable = Eris.GuildChannel | string;\n\nconst DiscordPlayerClientSymbol = Symbol('DiscordPlayerClient');\n\nexport function isClientProxy(client: any): boolean {\n  return Reflect.get(client, DiscordPlayerClientSymbol) != null;\n}\n\nexport function getCompatName(client: any): string {\n  return Reflect.get(client, DiscordPlayerClientSymbol) ?? null;\n}\n\nexport function isErisProxy(client: any): client is Eris.Client {\n  return Reflect.get(client, DiscordPlayerClientSymbol) === 'Eris';\n}\n\nexport function isErisClient(client: any): client is Eris.Client {\n  const { module, error } = Util.require('eris');\n\n  if (error) return false;\n\n  const eris = module as typeof import('eris');\n\n  return client instanceof eris.Client;\n}\n\nfunction declareProperty(target: any, key: string, value: any) {\n  Reflect.set(target, key, value);\n}\n\nfunction getProperty<T>(target: any, key: string): T {\n  return Reflect.get(target, key);\n}\n\n/**\n * Allows Eris clients to be used with discord-player. When this method is called, discord-player creates a proxy object that intercepts certain methods and properties to make it compatible with discord-player.\n * @param client The Eris client to be used.\n * @returns The Eris client with discord-player compatibility.\n */\nexport function createErisCompat(client: Eris.Client): Client {\n  const { module, error } = Util.require('eris');\n\n  if (error) throw error;\n\n  const eris = module as typeof import('eris');\n\n  erisVoiceEventsHandler(client);\n\n  const erisProxy = new Proxy(client, {\n    get(target, p) {\n      switch (p) {\n        case 'users':\n          return erisUsersProxy(target, eris);\n        case 'guilds':\n          return erisGuildsProxy(target, eris);\n        case 'channels':\n          return erisChannelsProxy(target, eris);\n        case '__dp_voiceStateUpdate_proxy':\n          return (handler: (a, b) => void) => erisVoiceStateUpdateProxy(target, erisProxy, handler);\n        case 'incrementMaxListeners':\n          return () => {\n            // @ts-expect-error patching\n            client.setMaxListeners(client.getMaxListeners() + 1);\n          };\n        case 'decrementMaxListeners':\n          return () => {\n            // @ts-expect-error patching\n            const listeners = client.getMaxListeners() - 1;\n\n            // @ts-expect-error patching\n            client.setMaxListeners(listeners < 0 ? 1 : listeners);\n          };\n        default:\n          // @ts-expect-error patching\n          return target[p];\n      }\n    },\n  });\n\n  Reflect.set(erisProxy, DiscordPlayerClientSymbol, 'Eris');\n\n  return erisProxy as unknown as Client;\n}\n\nfunction erisVoiceStateUpdateProxy(client: Eris.Client, proxy: Eris.Client, handler: (a, b) => void) {\n  client.on('voiceStateUpdate', (member, oldState) => {\n    try {\n      const proxiedOldState = {\n        channelId: oldState.channelID,\n        serverMute: oldState.mute,\n        suppress: oldState.suppress,\n        guild: {\n          id: oldState.guild.id,\n        },\n        member: {\n          id: oldState.user.id,\n        },\n      } as VoiceState;\n\n      const me = member.guild.members.get(client.user.id);\n      const resolvedChannel = member.guild.channels.get(member.voiceState.channelID);\n\n      const proxiedNewState = {\n        channelId: member.voiceState.channelID,\n        serverMute: member.voiceState.mute,\n        suppress: member.voiceState.suppress,\n        channel: erisResolvedChannelProxy(resolvedChannel, client),\n        member: {\n          id: member.id,\n        },\n        guild: {\n          id: member.guild.id,\n          members: {\n            me: {\n              id: me?.id,\n              voice: {\n                async setRequestToSpeak(value: boolean) {\n                  void value;\n                  return me?.voiceState;\n                  // if (me) {\n                  //   return me.voice.setRequestToSpeak(value);\n                  // }\n                },\n              },\n            },\n          },\n        },\n      } as VoiceState;\n\n      return handler(proxiedNewState, proxiedOldState);\n    } catch {\n      /* noop */\n    }\n  });\n}\n\nfunction erisVoiceEventsHandler(client: Eris.Client) {\n  let adapters = getProperty<Map<string, any>>(client, 'adapters');\n\n  if (!adapters) {\n    const collection = new Map<string, any>();\n    adapters = collection;\n    declareProperty(client, 'adapters', collection);\n  }\n\n  client.on('shardDisconnect', (_, shardId) => {\n    for (const [guildId, adapter] of adapters.entries()) {\n      if (client.guilds.get(guildId)?.shard.id === shardId) {\n        adapter.destroy();\n      }\n    }\n  });\n\n  client.on('rawWS', (packet) => {\n    switch (packet.t) {\n      case GatewayDispatchEvents.VoiceServerUpdate: {\n        const payload = packet.d as GatewayVoiceServerUpdateDispatchData;\n        adapters.get(payload.guild_id)?.onVoiceServerUpdate(payload);\n        return;\n      }\n      case GatewayDispatchEvents.VoiceStateUpdate: {\n        const payload = packet.d as GatewayVoiceStateUpdateDispatchData;\n\n        if (payload.guild_id && payload.session_id && payload.user_id === client.user.id) {\n          adapters.get(payload.guild_id)?.onVoiceStateUpdate(payload);\n        }\n\n        return;\n      }\n      default:\n        break;\n    }\n  });\n}\n\nfunction erisChannelsProxy(client: Eris.Client, eris: typeof import('eris')) {\n  const handler = {\n    client,\n    get cache() {\n      return {\n        get(id: string) {\n          return client.getChannel(id);\n        },\n        has(id: string) {\n          return id in client.channelGuildMap;\n        },\n      };\n    },\n    resolve(resolvable: string | ErisChannelResolvable) {\n      if (typeof resolvable === 'string') {\n        return erisResolvedChannelProxy(this.client.getChannel(resolvable) as Eris.GuildChannel, client);\n      }\n\n      if (resolvable instanceof eris.GuildChannel) {\n        return erisResolvedChannelProxy(resolvable, client);\n      }\n    },\n    resolveId(resolvable: ErisChannelResolvable) {\n      const channel = this.resolve(resolvable);\n      return channel?.id;\n    },\n  };\n\n  return handler;\n}\n\nfunction erisResolvedChannelProxy(\n  channel: Eris.GuildChannel | undefined,\n  client: Eris.Client,\n): Eris.GuildChannel | undefined {\n  if (!channel) return;\n\n  return new Proxy(channel, {\n    get(target, p) {\n      switch (p) {\n        case 'guild':\n          return erisVoiceAdapterProxy(target.guild, client);\n        case 'members':\n          return (target as Eris.VoiceChannel).voiceMembers;\n        case 'isVoiceBased':\n          return () => target.type === ChannelType.GuildVoice || target.type === ChannelType.GuildStageVoice;\n        case 'isVoice':\n          return () => target.type === ChannelType.GuildVoice;\n        case 'isStage':\n          return () => target.type === ChannelType.GuildStageVoice;\n        default:\n          // @ts-expect-error patching\n          return target[p];\n      }\n    },\n  });\n}\n\nfunction erisVoiceAdapterProxy(guild: Eris.Guild | undefined, client: Eris.Client): Eris.Guild | undefined {\n  if (!guild) return;\n\n  return new Proxy(guild, {\n    get(target, p) {\n      if (p === 'voiceAdapterCreator') {\n        return erisVoiceAdapterCreator(target, client);\n      }\n\n      // @ts-expect-error patching\n      return target[p];\n    },\n  });\n}\n\nfunction erisVoiceAdapterCreator(guild: Eris.Guild, client: Eris.Client): DiscordGatewayAdapterCreator {\n  return (methods) => {\n    let adapters = getProperty<Map<string, typeof methods>>(client, 'adapters');\n\n    if (!adapters) {\n      const collection = new Map<string, typeof methods>();\n      adapters = collection;\n      declareProperty(client, 'adapters', collection);\n    }\n\n    adapters.set(guild.id, methods);\n\n    return {\n      sendPayload(payload) {\n        if (guild.shard.status !== 'ready') return false;\n        guild.shard.sendWS(payload.op, payload.d);\n        return true;\n      },\n      destroy() {\n        adapters.delete(guild.id);\n      },\n    };\n  };\n}\n\nfunction erisGuildsProxy(client: Eris.Client, eris: typeof import('eris')) {\n  return new Proxy(client.guilds, {\n    get(target, p) {\n      if (p === 'cache') {\n        return target;\n      }\n\n      if (p === 'resolve' || p === 'resolveId') {\n        const resolver = function (resolvable: ErisGuildResolvable) {\n          if (typeof resolvable === 'string') {\n            return target.get(resolvable);\n          }\n\n          if (resolvable instanceof eris.Guild) {\n            return resolvable;\n          }\n\n          if (\n            resolvable instanceof eris.Member ||\n            resolvable instanceof eris.Guild ||\n            resolvable instanceof eris.GuildChannel ||\n            resolvable instanceof eris.Role\n          ) {\n            return resolvable.guild;\n          }\n        };\n\n        if (p === 'resolve') {\n          return resolver;\n        }\n\n        return (resolvable: ErisGuildResolvable) => {\n          const guild = resolver(resolvable);\n          return guild?.id;\n        };\n      }\n\n      // @ts-expect-error patching\n      return target[p];\n    },\n  });\n}\n\nfunction erisUsersProxy(client: Eris.Client, eris: typeof import('eris')) {\n  return new Proxy(client.users, {\n    get(target, p) {\n      if (p === 'cache') {\n        return target;\n      }\n\n      if (p === 'resolve' || p === 'resolveId') {\n        const resolver = function (resolvable: ErisUserResolvable) {\n          if (typeof resolvable === 'string') {\n            return target.get(resolvable);\n          }\n\n          if (resolvable instanceof eris.User) {\n            return resolvable;\n          }\n\n          if (resolvable instanceof eris.Member) {\n            return resolvable.user;\n          }\n        };\n\n        if (p === 'resolve') {\n          return resolver;\n        }\n\n        return (resolvable: ErisUserResolvable) => {\n          const user = resolver(resolvable);\n          return user?.id;\n        };\n      }\n\n      // @ts-expect-error patching\n      return target[p];\n    },\n  });\n}\n", "import { StageChannel, VoiceChannel } from 'discord.js';\nimport { TimeData } from '../types/types';\nimport { setTimeout } from 'node:timers/promises';\nimport { GuildQueue } from '../queue';\nimport { Playlist, Track } from '../fabric';\nimport { Exceptions } from '../errors';\nimport { randomInt } from 'node:crypto';\nimport {\n  createFilter,\n  createSpotifyFilter,\n  fixTrackSuffix,\n  removeLive,\n  removeRemastered,\n  youtube,\n  removeZeroWidth,\n  replaceNbsp,\n  replaceSmartQuotes,\n  removeCleanExplicit,\n} from '@web-scrobbler/metadata-filter';\nimport { TrackSource } from '../types/types';\n\nexport type RuntimeType = 'node' | 'deno' | 'bun' | 'unknown';\n\nexport interface Runtime {\n  name: RuntimeType;\n  version: string;\n}\n\nclass Util {\n  /**\n   * Utils\n   */\n  private constructor() {} // eslint-disable-line @typescript-eslint/no-empty-function\n\n  /**\n   * Gets the runtime information\n   */\n  static getRuntime(): Runtime {\n    const version = typeof navigator !== 'undefined' ? navigator.userAgent : null;\n\n    // @ts-ignore\n    if (typeof Deno !== 'undefined' && Deno.version) return { name: 'deno', version: Deno.version.deno };\n\n    // @ts-ignore\n    if (typeof Bun !== 'undefined' && Bun.version) return { name: 'bun', version: Bun.version };\n\n    if (typeof process !== 'undefined' && process.version) return { name: 'node', version: process.version };\n\n    return { name: 'unknown', version: version ?? 'unknown' };\n  }\n\n  /**\n   * Creates duration string\n   * @param {object} durObj The duration object\n   * @returns {string}\n   */\n  static durationString(durObj: Record<string, number>) {\n    return Object.values(durObj)\n      .map((m) => (isNaN(m) ? 0 : m))\n      .join(':');\n  }\n\n  /**\n   * Parses milliseconds to consumable time object\n   * @param {number} milliseconds The time in ms\n   * @returns {TimeData}\n   */\n  static parseMS(milliseconds: number) {\n    if (isNaN(milliseconds)) milliseconds = 0;\n    const round = milliseconds > 0 ? Math.floor : Math.ceil;\n\n    return {\n      days: round(milliseconds / 86400000),\n      hours: round(milliseconds / 3600000) % 24,\n      minutes: round(milliseconds / 60000) % 60,\n      seconds: round(milliseconds / 1000) % 60,\n    } as TimeData;\n  }\n\n  /**\n   * Builds time code\n   * @param {TimeData} duration The duration object\n   * @returns {string}\n   */\n  static buildTimeCode(duration: TimeData) {\n    const items = Object.keys(duration);\n    const required = ['days', 'hours', 'minutes', 'seconds'];\n\n    const parsed = items.filter((x) => required.includes(x)).map((m) => duration[m as keyof TimeData]);\n    const final = parsed\n      .slice(parsed.findIndex((x) => x !== 0))\n      .map((x) => x.toString().padStart(2, '0'))\n      .join(':');\n\n    return final.length <= 3 ? `0:${final.padStart(2, '0') || 0}` : final;\n  }\n\n  /**\n   * Formats duration\n   * @param {number} duration The duration in ms\n   */\n  static formatDuration(duration: number) {\n    return this.buildTimeCode(this.parseMS(duration));\n  }\n\n  /**\n   * Picks last item of the given array\n   * @param {any[]} arr The array\n   * @returns {any}\n   */\n  // eslint-disable-next-line @typescript-eslint/no-explicit-any\n  static last<T = any>(arr: T[]): T {\n    if (!Array.isArray(arr)) return arr;\n    return arr[arr.length - 1];\n  }\n\n  /**\n   * Checks if the voice channel is empty\n   * @param {VoiceChannel|StageChannel} channel The voice channel\n   * @returns {boolean}\n   */\n  static isVoiceEmpty(channel: VoiceChannel | StageChannel) {\n    return channel && channel.members.filter((member) => !member.user.bot).size === 0;\n  }\n\n  /**\n   * Cleans the track title\n   * @param title The title\n   * @param source The source\n   * @returns Cleaned title\n   */\n  static cleanTitle(title: string, source: TrackSource) {\n    try {\n      const filterOpts = {\n        // prettier-ignore\n        track: [\n                    removeRemastered,\n                    removeLive,\n                    fixTrackSuffix,\n                    removeZeroWidth,\n                    replaceNbsp,\n                    replaceSmartQuotes,\n                    removeCleanExplicit\n                ],\n      };\n      const spotifyFilter = createFilter(filterOpts);\n      spotifyFilter.extend(createSpotifyFilter());\n      const defaultFilter = createFilter(filterOpts);\n\n      switch (source) {\n        case 'youtube':\n          return youtube(title);\n        case 'spotify':\n          return spotifyFilter.filterField('track', title);\n        default:\n          return defaultFilter.filterField('track', title);\n      }\n    } catch {\n      return title;\n    }\n  }\n\n  /**\n   * Safer require\n   * @param {string} id Node require id\n   * @returns {any}\n   */\n  static require(id: string) {\n    try {\n      return { module: require(id), error: null };\n    } catch (error) {\n      return { module: null, error };\n    }\n  }\n\n  static async import(id: string) {\n    try {\n      const mod = await import(id);\n      return { module: mod, error: null };\n    } catch (error) {\n      return { module: null, error };\n    }\n  }\n\n  /**\n   * Asynchronous timeout\n   * @param {number} time The time in ms to wait\n   * @returns {Promise<unknown>}\n   */\n  static wait(time: number) {\n    return setTimeout(time, undefined, { ref: false });\n  }\n\n  static noop() {} // eslint-disable-line @typescript-eslint/no-empty-function\n\n  static async getFetch() {\n    if ('fetch' in globalThis) return globalThis.fetch;\n    for (const lib of ['node-fetch', 'undici']) {\n      try {\n        return await import(lib).then((res) => res.fetch || res.default?.fetch || res.default);\n      } catch {\n        try {\n          // eslint-disable-next-line\n          const res = require(lib);\n          if (res) return res.fetch || res.default?.fetch || res.default;\n        } catch {\n          // no?\n        }\n      }\n    }\n  }\n\n  static warn(message: string, code = 'DeprecationWarning', detail?: string) {\n    process.emitWarning(message, {\n      code,\n      detail,\n    });\n  }\n\n  static randomChoice<T>(src: T[]): T {\n    return src[randomInt(src.length)];\n  }\n\n  static arrayCloneShuffle<T>(src: T[]): T[] {\n    const arr = src.slice();\n\n    let m = arr.length;\n\n    while (m) {\n      const i = Math.floor(Math.random() * m--);\n      [arr[m], arr[i]] = [arr[i], arr[m]];\n    }\n\n    return arr;\n  }\n}\n\nexport const VALIDATE_QUEUE_CAP = (queue: GuildQueue, items: Playlist | Track | Track[]) => {\n  const tracks = items instanceof Playlist ? items.tracks : Array.isArray(items) ? items : [items];\n\n  if (queue.maxSize < 1 || queue.maxSize === Infinity) return;\n\n  const maxCap = queue.getCapacity();\n\n  if (maxCap < tracks.length) {\n    throw Exceptions.ERR_OUT_OF_SPACE('tracks queue', maxCap, tracks.length);\n  }\n};\n\nexport { Util };\n", "import { User, escapeMarkdown, SnowflakeUtil, GuildVoiceChannelResolvable, APIUser } from 'discord.js';\nimport { Player, PlayerNodeInitializationResult, PlayerNodeInitializerOptions } from '../Player';\nimport { RawTrackData, SearchQueryType, TrackJSON } from '../types/types';\nimport { Playlist } from './Playlist';\nimport { GuildQueue } from '../queue/GuildQueue';\nimport { BaseExtractor } from '../extractors/BaseExtractor';\nimport { Collection } from '@discord-player/utils';\nimport { TypeUtil } from '../utils/TypeUtil';\nimport { SerializedType, tryIntoThumbnailString } from '../utils/serde';\nimport { Exceptions } from '../errors';\nimport { Util } from '../utils/Util';\n\nexport type TrackResolvable = Track | string | number;\n\nexport type WithMetadata<T extends object, M> = T & {\n  metadata: M;\n  requestMetadata(): Promise<M>;\n};\n\nexport type SerializedTrack = ReturnType<Track['serialize']>;\n\nexport class Track<T = unknown> {\n  public title: string;\n  public description: string;\n  public author: string;\n  public url: string;\n  public thumbnail: string;\n  public duration: string;\n  public views: number;\n  public requestedBy: User | null = null;\n  public playlist?: Playlist;\n  public queryType: SearchQueryType | null | undefined = null;\n  // eslint-disable-next-line @typescript-eslint/no-explicit-any\n  public raw: any;\n  public extractor: BaseExtractor | null = null;\n  public readonly id = SnowflakeUtil.generate().toString();\n  private __metadata: T | null = null;\n  private __reqMetadataFn: () => Promise<T | null>;\n  public cleanTitle: string;\n  public live: boolean = false;\n  public bridgedExtractor: BaseExtractor | null = null;\n  public bridgedTrack: Track | null = null;\n\n  /**\n   * Track constructor\n   * @param player The player that instantiated this Track\n   * @param data Track data\n   */\n  public constructor(public readonly player: Player, data: Partial<WithMetadata<RawTrackData, T>>) {\n    this.title = escapeMarkdown(data.title ?? '');\n    this.author = data.author ?? '';\n    this.url = data.url ?? '';\n    this.thumbnail = data.thumbnail ?? '';\n    this.duration = data.duration ?? '';\n    this.views = data.views ?? 0;\n    this.queryType = data.queryType;\n    this.requestedBy = data.requestedBy || null;\n    this.playlist = data.playlist;\n    this.description = `${this.title} by ${this.author}`;\n    this.raw = Object.assign({}, { source: data.raw?.source ?? data.source }, data.raw ?? data);\n    this.__metadata = data.metadata ?? null;\n    this.__reqMetadataFn = data.requestMetadata || (() => Promise.resolve<T | null>(null));\n    this.cleanTitle = data.cleanTitle ?? Util.cleanTitle(this.title, this.source);\n    this.live = data.live ?? false;\n  }\n\n  /**\n   * Request metadata for this track\n   */\n  public async requestMetadata() {\n    const res = await this.__reqMetadataFn();\n\n    this.setMetadata(res);\n\n    return res;\n  }\n\n  /**\n   * Set metadata for this track\n   */\n  public setMetadata(m: T | null) {\n    this.__metadata = m;\n  }\n\n  /**\n   * Metadata of this track\n   */\n  public get metadata() {\n    return this.__metadata;\n  }\n\n  /**\n   * If this track has metadata\n   */\n  public get hasMetadata() {\n    return this.metadata != null;\n  }\n\n  /**\n   * The queue in which this track is located\n   */\n  public get queue(): GuildQueue {\n    return this.player.nodes.cache.find((q) => q.tracks.some((ab) => ab.id === this.id))!;\n  }\n\n  /**\n   * The track duration in millisecond\n   */\n  public get durationMS(): number {\n    const times = (n: number, t: number) => {\n      let tn = 1;\n      for (let i = 0; i < t; i++) tn *= n;\n      return t <= 0 ? 1000 : tn * 1000;\n    };\n\n    return this.duration\n      .split(':')\n      .reverse()\n      .map((m, i) => parseInt(m) * times(60, i))\n      .reduce((a, c) => a + c, 0);\n  }\n\n  /**\n   * Discord hyperlink representation of this track\n   */\n  public toHyperlink(): string /* not using `[${string}](${string})` yet */ {\n    return `[${this.title}](${this.url})`;\n  }\n\n  /**\n   * Returns source of this track\n   */\n  public get source() {\n    return this.raw?.source ?? 'arbitrary';\n  }\n\n  /**\n   * String representation of this track\n   */\n  public toString(): string {\n    return `${this.title} by ${this.author}`;\n  }\n\n  /**\n   * Raw JSON representation of this track\n   */\n  public toJSON(hidePlaylist?: boolean) {\n    return {\n      id: this.id,\n      title: this.title,\n      description: this.description,\n      author: this.author,\n      url: this.url,\n      thumbnail: this.thumbnail,\n      duration: this.duration,\n      durationMS: this.durationMS,\n      views: this.views,\n      requestedBy: this.requestedBy?.id || null,\n      playlist: hidePlaylist ? null : this.playlist?.toJSON() ?? null,\n    } as TrackJSON;\n  }\n\n  /**\n   * Serialized track data that can be reconstructed\n   */\n  public serialize() {\n    return {\n      title: this.title,\n      description: this.description,\n      author: this.author,\n      url: this.url,\n      thumbnail: TypeUtil.isString(this.thumbnail) ? this.thumbnail : tryIntoThumbnailString(this.thumbnail),\n      duration: this.duration,\n      views: this.views ?? 0,\n      requested_by: this.requestedBy?.toJSON() ?? null,\n      source: this.source,\n      live: false,\n      query_type: this.queryType,\n      extractor: this.extractor?.identifier ?? null,\n      metadata: this.metadata,\n      $type: SerializedType.Track,\n      $encoder_version: '7.0.0-dev.5',\n    };\n  }\n\n  /**\n   * Construct a track from serialized data\n   * @param player Player instance\n   * @param data Serialized data\n   */\n  public static fromSerialized(player: Player, data: ReturnType<Track['serialize']>) {\n    if (data.$type !== SerializedType.Track)\n      throw Exceptions.ERR_INVALID_ARG_TYPE('data', 'SerializedTrack', 'malformed data');\n    const track = new Track(player, {\n      ...data,\n      requestedBy: data.requested_by\n        ? (() => {\n            const res = data.requested_by as APIUser;\n            try {\n              const resolved = player.client.users.resolve(res.id);\n              if (resolved) return resolved;\n              if (player.client.users.cache.has(res.id)) return player.client.users.cache.get(res.id)!;\n              // @ts-expect-error\n              const user = new User(player.client, res);\n              return user;\n            } catch {\n              return null;\n            }\n          })()\n        : null,\n      queryType: data.query_type ?? undefined,\n    });\n\n    track.setMetadata(data.metadata);\n\n    return track;\n  }\n\n  /**\n   * Get belonging queues of this track\n   */\n  public getBelongingQueues() {\n    const nodes = this.player.nodes.cache.filter((node) => node.tracks.some((t) => t.id === this.id));\n\n    return nodes as Collection<string, GuildQueue<unknown>>;\n  }\n\n  /**\n   * Play this track to the given voice channel. If queue exists and another track is being played, this track will be added to the queue.\n   * @param channel Voice channel on which this track shall be played\n   * @param options Node initialization options\n   */\n  public async play<T = unknown>(\n    channel: GuildVoiceChannelResolvable,\n    options?: PlayerNodeInitializerOptions<T>,\n  ): Promise<PlayerNodeInitializationResult<T>> {\n    const fn = this.player.play.bind(this.player);\n\n    return await fn(channel, this, options);\n  }\n}\n", "export class TypeUtil {\n  private constructor() {\n    return TypeUtil;\n  }\n\n  // eslint-disable-next-line @typescript-eslint/ban-types\n  public static isFunction(t: unknown): t is Function {\n    return typeof t === 'function';\n  }\n\n  public static isNumber(t: unknown): t is number {\n    return typeof t === 'number' && !isNaN(t);\n  }\n\n  public static isString(t: unknown): t is string {\n    return typeof t === 'string';\n  }\n\n  public static isBoolean(t: unknown): t is boolean {\n    return typeof t === 'boolean';\n  }\n\n  public static isNullish(t: unknown): t is null | undefined {\n    return t == null;\n  }\n\n  public static isArray(t: unknown): t is unknown[] {\n    return Array.isArray(t);\n  }\n\n  public static isError(t: unknown): t is Error {\n    return t instanceof Error;\n  }\n}\n", "const DiscordPlayerErrors = {\n  ERR_OUT_OF_SPACE: {\n    name: 'ERR_OUT_OF_SPACE',\n    type: RangeError,\n    createError(target: string, capacity: number, total: number) {\n      return `[${this.constructor.name}] Max capacity reached for ${target} (Capacity ${capacity}/Total ${total})`;\n    },\n  },\n  ERR_INVALID_ARG_TYPE: {\n    name: 'ERR_INVALID_ARG_TYPE',\n    type: TypeError,\n    createError(target: string, expectation: string, found: string) {\n      return `[${this.constructor.name}] Expected ${target} to be \"${expectation}\", received \"${found}\"`;\n    },\n  },\n  ERR_NO_RESULT: {\n    name: 'ERR_NO_RESULT',\n    type: Error,\n    createError(message: string) {\n      return `[${this.constructor.name}] ${message}`;\n    },\n  },\n  ERR_NOT_IMPLEMENTED: {\n    name: 'ERR_NOT_IMPLEMENTED',\n    type: Error,\n    createError(target: string) {\n      return `[${this.constructor.name}] ${target} is not yet implemented`;\n    },\n  },\n  ERR_NOT_EXISTING: {\n    name: 'ERR_NOT_EXISTING',\n    type: Error,\n    createError(target: string) {\n      return `[${this.constructor.name}] ${target} does not exist`;\n    },\n  },\n  ERR_OUT_OF_RANGE: {\n    name: 'ERR_OUT_OF_RANGE',\n    type: RangeError,\n    createError(target: string, value: string, minimum: string, maximum: string) {\n      return `[${this.constructor.name}] ${target} is out of range (Expected minimum ${maximum} and maximum ${maximum}, got ${value})`;\n    },\n  },\n  ERR_NO_VOICE_CONNECTION: {\n    name: 'ERR_NO_VOICE_CONNECTION',\n    type: Error,\n    createError(message?: string) {\n      return (\n        `[${this.constructor.name}] ` +\n        (message || 'No voice connection available, maybe connect to a voice channel first?')\n      );\n    },\n  },\n  ERR_VOICE_CONNECTION_DESTROYED: {\n    name: 'ERR_VOICE_CONNECTION_DESTROYED',\n    type: Error,\n    createError() {\n      return `[${this.constructor.name}] ` + 'Cannot use destroyed voice connection';\n    },\n  },\n  ERR_NO_VOICE_CHANNEL: {\n    name: 'ERR_NO_VOICE_CHANNEL',\n    type: Error,\n    createError() {\n      return `[${this.constructor.name}] ` + 'Could not get the voice channel';\n    },\n  },\n  ERR_INVALID_VOICE_CHANNEL: {\n    name: 'ERR_INVALID_VOICE_CHANNEL',\n    type: Error,\n    createError() {\n      return `[${this.constructor.name}] ` + 'Expected a voice channel';\n    },\n  },\n  ERR_NO_RECEIVER: {\n    name: 'ERR_NO_RECEIVER',\n    type: Error,\n    createError(message?: string) {\n      return (\n        `[${this.constructor.name}] ` +\n        (message || 'No voice receiver is available, maybe connect to a voice channel first?')\n      );\n    },\n  },\n  ERR_FFMPEG_LOCATOR: {\n    name: 'ERR_FFMPEG_LOCATOR',\n    type: Error,\n    createError(message: string) {\n      return `[${this.constructor.name}] ` + message;\n    },\n  },\n  ERR_NO_AUDIO_RESOURCE: {\n    name: 'ERR_NO_AUDIO_RESOURCE',\n    type: Error,\n    createError(message?: string) {\n      return `[${this.constructor.name}] ` + (message || 'Expected an audio resource');\n    },\n  },\n  ERR_NO_GUILD_QUEUE: {\n    name: 'ERR_NO_GUILD_QUEUE',\n    type: Error,\n    createError(message?: string) {\n      return `[${this.constructor.name}] ` + (message || 'Expected a guild queue');\n    },\n  },\n  ERR_NO_GUILD: {\n    name: 'ERR_NO_GUILD',\n    type: Error,\n    createError(message?: string) {\n      return `[${this.constructor.name}] ` + (message || 'Expected a guild');\n    },\n  },\n  ERR_INFO_REQUIRED: {\n    name: 'ERR_INFO_REQUIRED',\n    type: Error,\n    createError(target: string, actual: string) {\n      return `[${this.constructor.name}] Expected ${target}, found \"${actual}\"`;\n    },\n  },\n  ERR_SERIALIZATION_FAILED: {\n    name: 'ERR_SERIALIZATION_FAILED',\n    type: Error,\n    createError() {\n      return `[${this.type.name}]` + \"Don't know how to serialize this data\";\n    },\n  },\n  ERR_DESERIALIZATION_FAILED: {\n    name: 'ERR_DESERIALIZATION_FAILED',\n    type: Error,\n    createError() {\n      return `[${this.type.name}]` + \"Don't know how to deserialize this data\";\n    },\n  },\n  ERR_ILLEGAL_HOOK_INVOCATION: {\n    name: 'ERR_ILLEGAL_HOOK_INVOCATION',\n    type: Error,\n    createError(target: string, message?: string) {\n      return `[${this.type.name}]` + `Illegal invocation of ${target} hook.${message ? ` ${message}` : ''}`;\n    },\n  },\n  ERR_NOT_EXISTING_MODULE: {\n    name: 'ERR_NOT_EXISTING_MODULE',\n    type: Error,\n    createError(target: string, description = '') {\n      return (\n        `[${this.type.name}]` +\n        `${target} module does not exist. Install it with \\`npm install ${target}\\`.${\n          description ? ' ' + description : ''\n        }`\n      );\n    },\n  },\n  ERR_BRIDGE_FAILED: {\n    name: 'ERR_BRIDGE_FAILED',\n    type: Error,\n    createError(id: string | null, error: string) {\n      return (\n        `[${this.type.name}]` +\n        `${id ? `(Extractor Execution Context ID is ${id})` : ''}Failed to bridge this query:\\n${error}`\n      );\n    },\n  },\n} as const;\n\ntype FinalException<O extends (typeof DiscordPlayerErrors)[keyof typeof DiscordPlayerErrors]> = {\n  name: O['name'];\n} & InstanceType<O['type']>;\n\ntype DiscordPlayerException = {\n  [K in keyof typeof DiscordPlayerErrors]: (\n    ...args: Parameters<(typeof DiscordPlayerErrors)[K]['createError']>\n  ) => FinalException<(typeof DiscordPlayerErrors)[K]>;\n};\n\nconst target = {} as DiscordPlayerException;\n\nconst handler: ProxyHandler<typeof target> = {\n  get(target, p: keyof typeof DiscordPlayerErrors, receiver) {\n    const err = DiscordPlayerErrors[p];\n\n    if (!err) return Reflect.get(target, p, receiver);\n\n    return (...args: Parameters<(typeof err)['createError']>) => {\n      // @ts-expect-error\n      const exception = new err.type(err.createError(...args));\n      exception.name = err.name;\n\n      return exception;\n    };\n  },\n};\n\nexport const ErrorCodes = (() => {\n  type ErrCodes = {\n    -readonly [K in keyof typeof DiscordPlayerErrors]: (typeof DiscordPlayerErrors)[K]['name'];\n  };\n\n  const dict = {} as ErrCodes;\n\n  for (const prop in DiscordPlayerErrors) {\n    // @ts-expect-error\n    dict[prop] = prop;\n  }\n\n  return Object.freeze(dict);\n})();\nexport const Exceptions = new Proxy(target, handler);\n", "/* eslint-disable @typescript-eslint/no-explicit-any */\n\nimport { Exceptions } from '../errors';\nimport { Playlist, type SerializedTrack, Track, SerializedPlaylist } from '../fabric';\nimport { TypeUtil } from './TypeUtil';\nimport { Buffer } from 'buffer';\nimport { Player } from '../Player';\n\nexport enum SerializedType {\n  Track = 'track',\n  Playlist = 'playlist',\n}\n\nexport type Encodable = SerializedTrack | SerializedPlaylist;\n\nconst isTrack = (data: any): data is SerializedTrack => data.$type === SerializedType.Track;\nconst isPlaylist = (data: any): data is SerializedPlaylist => data.$type === SerializedType.Playlist;\n\nexport function serialize(data: Track | Playlist | any) {\n  if (data instanceof Track) return data.serialize();\n  if (data instanceof Playlist) return data.serialize();\n\n  try {\n    return data.toJSON();\n  } catch {\n    throw Exceptions.ERR_SERIALIZATION_FAILED();\n  }\n}\n\nexport function deserialize(player: Player, data: Encodable) {\n  if (isTrack(data)) return Track.fromSerialized(player, data);\n  if (isPlaylist(data)) return Playlist.fromSerialized(player, data);\n\n  throw Exceptions.ERR_DESERIALIZATION_FAILED();\n}\n\nexport function encode(data: Encodable) {\n  const str = JSON.stringify(data);\n\n  return Buffer.from(str).toString('base64');\n}\n\nexport function decode(data: string) {\n  const str = Buffer.from(data, 'base64').toString();\n\n  return JSON.parse(str);\n}\n\nexport function tryIntoThumbnailString(data: any) {\n  if (!data) return null;\n  try {\n    if (TypeUtil.isString(data)) return data;\n    return data?.url ?? data?.thumbnail?.url ?? null;\n  } catch {\n    return null;\n  }\n}\n", "import { Player, PlayerNodeInitializationResult, PlayerNodeInitializerOptions } from '../Player';\nimport { Track } from './Track';\nimport { PlaylistInitData, PlaylistJSON, TrackJSON, TrackSource } from '../types/types';\nimport { Util } from '../utils/Util';\nimport { GuildVoiceChannelResolvable } from 'discord.js';\nimport { SerializedType, tryIntoThumbnailString } from '../utils/serde';\nimport { TypeUtil } from '../utils/TypeUtil';\nimport { Exceptions } from '../errors';\n\nexport type SerializedPlaylist = ReturnType<Playlist['serialize']>;\n\nexport class Playlist {\n  public readonly player: Player;\n  public tracks: Track[];\n  public title: string;\n  public description: string;\n  public thumbnail: string;\n  public type: 'album' | 'playlist';\n  public source: TrackSource;\n  public author: {\n    name: string;\n    url: string;\n  };\n  public id: string;\n  public url: string;\n  public readonly rawPlaylist?: any; // eslint-disable-line @typescript-eslint/no-explicit-any\n\n  /**\n   * Playlist constructor\n   * @param {Player} player The player\n   * @param {PlaylistInitData} data The data\n   */\n  constructor(player: Player, data: PlaylistInitData) {\n    /**\n     * The player\n     * @name Playlist#player\n     * @type {Player}\n     * @readonly\n     */\n    this.player = player;\n\n    /**\n     * The tracks in this playlist\n     * @name Playlist#tracks\n     * @type {Track[]}\n     */\n    this.tracks = data.tracks ?? [];\n\n    /**\n     * The author of this playlist\n     * @name Playlist#author\n     * @type {object}\n     */\n    this.author = data.author;\n\n    /**\n     * The description\n     * @name Playlist#description\n     * @type {string}\n     */\n    this.description = data.description;\n\n    /**\n     * The thumbnail of this playlist\n     * @name Playlist#thumbnail\n     * @type {string}\n     */\n    this.thumbnail = data.thumbnail;\n\n    /**\n     * The playlist type:\n     * - `album`\n     * - `playlist`\n     * @name Playlist#type\n     * @type {string}\n     */\n    this.type = data.type;\n\n    /**\n     * The source of this playlist:\n     * - `youtube`\n     * - `soundcloud`\n     * - `spotify`\n     * - `arbitrary`\n     * @name Playlist#source\n     * @type {string}\n     */\n    this.source = data.source;\n\n    /**\n     * The playlist id\n     * @name Playlist#id\n     * @type {string}\n     */\n    this.id = data.id;\n\n    /**\n     * The playlist url\n     * @name Playlist#url\n     * @type {string}\n     */\n    this.url = data.url;\n\n    /**\n     * The playlist title\n     * @type {string}\n     */\n    this.title = data.title;\n\n    /**\n     * @name Playlist#rawPlaylist\n     * @type {any}\n     * @readonly\n     */\n  }\n\n  *[Symbol.iterator]() {\n    yield* this.tracks;\n  }\n\n  /**\n   * Estimated duration of this playlist\n   */\n  public get estimatedDuration() {\n    return this.tracks.reduce((p, c) => p + c.durationMS, 0);\n  }\n\n  /**\n   * Formatted estimated duration of this playlist\n   */\n  public get durationFormatted() {\n    return Util.buildTimeCode(Util.parseMS(this.estimatedDuration));\n  }\n\n  /**\n   * JSON representation of this playlist\n   * @param {boolean} [withTracks=true] If it should build json with tracks\n   * @returns {PlaylistJSON}\n   */\n  toJSON(withTracks = true) {\n    const payload = {\n      id: this.id,\n      url: this.url,\n      title: this.title,\n      description: this.description,\n      thumbnail: this.thumbnail,\n      type: this.type,\n      source: this.source,\n      author: this.author,\n      tracks: [] as TrackJSON[],\n    };\n\n    if (withTracks) payload.tracks = this.tracks.map((m) => m.toJSON(true));\n\n    return payload as PlaylistJSON;\n  }\n\n  /**\n   * Serialize this playlist into reconstructable data\n   */\n  public serialize() {\n    return {\n      tracks: this.tracks.map((m) => m.serialize()),\n      title: this.title,\n      description: this.description,\n      thumbnail: TypeUtil.isString(this.thumbnail) ? this.thumbnail : tryIntoThumbnailString(this.thumbnail),\n      type: this.type,\n      source: this.source,\n      author: this.author,\n      id: this.id,\n      url: this.url,\n      $type: SerializedType.Playlist,\n      $encoder_version: '7.0.0-dev.5',\n    };\n  }\n\n  /**\n   * Deserialize this playlist from serialized data\n   * @param player Player instance\n   * @param data Serialized data\n   */\n  public static fromSerialized(player: Player, data: SerializedPlaylist) {\n    if (data.$type !== SerializedType.Playlist)\n      throw Exceptions.ERR_INVALID_ARG_TYPE('data', 'SerializedPlaylist', 'malformed data');\n    return new Playlist(player, {\n      ...data,\n      tracks: data.tracks.map((m) => Track.fromSerialized(player, m)),\n    });\n  }\n\n  /**\n   * Play this playlist to the given voice channel. If queue exists and another track is being played, this playlist will be added to the queue.\n   * @param channel Voice channel on which this playlist shall be played\n   * @param options Node initialization options\n   */\n  public async play<T = unknown>(\n    channel: GuildVoiceChannelResolvable,\n    options?: PlayerNodeInitializerOptions<T>,\n  ): Promise<PlayerNodeInitializationResult<T>> {\n    const fn = this.player.play.bind(this.player);\n\n    return await fn(channel, this, options);\n  }\n}\n", "import type { User, UserResolvable, VoiceState } from 'discord.js';\nimport type { GuildQueue } from '../queue';\nimport type { Track } from '../fabric/Track';\nimport type { Playlist } from '../fabric/Playlist';\nimport type { QueryCacheProvider } from '../utils/QueryCache';\n\n// @ts-ignore\nimport type { BridgeProvider } from '@discord-player/extractor';\n\nexport type FiltersName = keyof QueueFilters;\n\nexport interface PlayerSearchResult {\n  playlist: Playlist | null;\n  tracks: Track[];\n}\n\n/**\n * Represents FFmpeg filters\n */\nexport interface QueueFilters {\n  bassboost_low?: boolean;\n  bassboost?: boolean;\n  bassboost_high?: boolean;\n  '8D'?: boolean;\n  vaporwave?: boolean;\n  nightcore?: boolean;\n  phaser?: boolean;\n  tremolo?: boolean;\n  vibrato?: boolean;\n  reverse?: boolean;\n  treble?: boolean;\n  normalizer?: boolean;\n  normalizer2?: boolean;\n  surrounding?: boolean;\n  pulsator?: boolean;\n  subboost?: boolean;\n  karaoke?: boolean;\n  flanger?: boolean;\n  gate?: boolean;\n  haas?: boolean;\n  mcompand?: boolean;\n  mono?: boolean;\n  mstlr?: boolean;\n  mstrr?: boolean;\n  compressor?: boolean;\n  expander?: boolean;\n  softlimiter?: boolean;\n  chorus?: boolean;\n  chorus2d?: boolean;\n  chorus3d?: boolean;\n  fadein?: boolean;\n  dim?: boolean;\n  earrape?: boolean;\n  lofi?: boolean;\n  silenceremove?: boolean;\n}\n\n/**\n * The track source:\n * - soundcloud\n * - youtube\n * - spotify\n * - apple_music\n * - arbitrary\n */\nexport type TrackSource = 'soundcloud' | 'youtube' | 'spotify' | 'apple_music' | 'arbitrary';\n\nexport interface RawTrackData {\n  /**\n   * The title\n   */\n  title: string;\n  /**\n   * The description\n   */\n  description: string;\n  /**\n   * The author\n   */\n  author: string;\n  /**\n   * The url\n   */\n  url: string;\n  /**\n   * The thumbnail\n   */\n  thumbnail: string;\n  /**\n   * The duration\n   */\n  duration: string;\n  /**\n   * The duration in ms\n   */\n  views: number;\n  /**\n   * The user who requested this track\n   */\n  requestedBy?: User | null;\n  /**\n   * The playlist\n   */\n  playlist?: Playlist;\n  /**\n   * The source\n   */\n  source?: TrackSource;\n  /**\n   * The engine\n   */\n  engine?: any; // eslint-disable-line @typescript-eslint/no-explicit-any\n  /**\n   * If this track is live\n   */\n  live?: boolean;\n  /**\n   * The raw data\n   */\n  raw?: any; // eslint-disable-line @typescript-eslint/no-explicit-any\n  /**\n   * The query type\n   */\n  queryType?: SearchQueryType;\n  /**\n   * The seralised title\n   */\n  cleanTitle?: string;\n}\n\nexport interface TimeData {\n  /**\n   * Time in days\n   */\n  days: number;\n  /**\n   * Time in hours\n   */\n  hours: number;\n  /**\n   * Time in minutes\n   */\n  minutes: number;\n  /**\n   * Time in seconds\n   */\n  seconds: number;\n}\n\nexport interface PlayerProgressbarOptions {\n  /**\n   * If it should render time codes\n   */\n  timecodes?: boolean;\n  /**\n   * If it should create progress bar for the whole queue\n   */\n  length?: number;\n  /**\n   * The bar length\n   */\n  leftChar?: string;\n  /**\n   * The elapsed time track\n   */\n  rightChar?: string;\n  /**\n   * The remaining time track\n   */\n  separator?: string;\n  /**\n   * The separation between timestamp and line\n   */\n  indicator?: string;\n  /**\n   * The indicator\n   */\n  queue?: boolean;\n}\n\n/**\n * The search query type\n * This can be one of:\n * - AUTO\n * - YOUTUBE\n * - YOUTUBE_PLAYLIST\n * - SOUNDCLOUD_TRACK\n * - SOUNDCLOUD_PLAYLIST\n * - SOUNDCLOUD\n * - SPOTIFY_SONG\n * - SPOTIFY_ALBUM\n * - SPOTIFY_PLAYLIST\n * - SPOTIFY_SEARCH\n * - FACEBOOK\n * - VIMEO\n * - ARBITRARY\n * - REVERBNATION\n * - YOUTUBE_SEARCH\n * - YOUTUBE_VIDEO\n * - SOUNDCLOUD_SEARCH\n * - APPLE_MUSIC_SONG\n * - APPLE_MUSIC_ALBUM\n * - APPLE_MUSIC_PLAYLIST\n * - APPLE_MUSIC_SEARCH\n * - FILE\n * - AUTO_SEARCH\n * @typedef {string} QueryType\n */\nexport const QueryType = {\n  AUTO: 'auto',\n  YOUTUBE: 'youtube',\n  YOUTUBE_PLAYLIST: 'youtubePlaylist',\n  SOUNDCLOUD_TRACK: 'soundcloudTrack',\n  SOUNDCLOUD_PLAYLIST: 'soundcloudPlaylist',\n  SOUNDCLOUD: 'soundcloud',\n  SPOTIFY_SONG: 'spotifySong',\n  SPOTIFY_ALBUM: 'spotifyAlbum',\n  SPOTIFY_PLAYLIST: 'spotifyPlaylist',\n  SPOTIFY_SEARCH: 'spotifySearch',\n  FACEBOOK: 'facebook',\n  VIMEO: 'vimeo',\n  ARBITRARY: 'arbitrary',\n  REVERBNATION: 'reverbnation',\n  YOUTUBE_SEARCH: 'youtubeSearch',\n  YOUTUBE_VIDEO: 'youtubeVideo',\n  SOUNDCLOUD_SEARCH: 'soundcloudSearch',\n  APPLE_MUSIC_SONG: 'appleMusicSong',\n  APPLE_MUSIC_ALBUM: 'appleMusicAlbum',\n  APPLE_MUSIC_PLAYLIST: 'appleMusicPlaylist',\n  APPLE_MUSIC_SEARCH: 'appleMusicSearch',\n  FILE: 'file',\n  AUTO_SEARCH: 'autoSearch',\n} as const;\n\nexport type SearchQueryType = keyof typeof QueryType | (typeof QueryType)[keyof typeof QueryType];\n\n/* eslint-disable @typescript-eslint/no-explicit-any */\nexport interface PlayerEvents {\n  debug: (message: string) => any;\n  error: (error: Error) => any;\n  voiceStateUpdate: (queue: GuildQueue, oldState: VoiceState, newState: VoiceState) => any;\n}\n\nexport const PlayerEvent = {\n  debug: 'debug',\n  Debug: 'debug',\n  error: 'error',\n  Error: 'error',\n  voiceStateUpdate: 'voiceStateUpdate',\n  VoiceStateUpdate: 'voiceStateUpdate',\n} as const;\nexport type PlayerEvent = (typeof PlayerEvent)[keyof typeof PlayerEvent];\n\n/* eslint-enable @typescript-eslint/no-explicit-any */\n\nexport interface PlayOptions {\n  /**\n   * If this play was triggered for filters update\n   */\n  filtersUpdate?: boolean;\n  /**\n   * FFmpeg args passed to encoder\n   */\n  encoderArgs?: string[];\n  /**\n   * Time to seek to before playing\n   */\n  seek?: number;\n  /**\n   * If it should start playing the provided track immediately\n   */\n  immediate?: boolean;\n}\n\nexport type QueryExtractorSearch = `ext:${string}`;\n\nexport interface SearchOptions {\n  /**\n   * The user who requested this search\n   */\n  requestedBy?: UserResolvable;\n  /**\n   * The query search engine, can be extractor name to target specific one (custom)\n   */\n  searchEngine?: SearchQueryType | QueryExtractorSearch;\n  /**\n   * List of the extractors to block\n   */\n  blockExtractors?: string[];\n  /**\n   * If it should ignore query cache lookup\n   */\n  ignoreCache?: boolean;\n  /**\n   * Fallback search engine to use\n   */\n  // eslint-disable-next-line @typescript-eslint/no-explicit-any\n  requestOptions?: any;\n  /**\n   * Fallback search engine to use\n   */\n  fallbackSearchEngine?: (typeof QueryType)[keyof typeof QueryType];\n}\n\n/**\n * The queue repeat mode. This can be one of:\n * - OFF\n * - TRACK\n * - QUEUE\n * - AUTOPLAY\n */\nexport enum QueueRepeatMode {\n  /**\n   * Disable repeat mode.\n   */\n  OFF = 0,\n  /**\n   * Repeat the current track.\n   */\n  TRACK = 1,\n  /**\n   * Repeat the entire queue.\n   */\n  QUEUE = 2,\n  /**\n   * When last track ends, play similar tracks in the future if queue is empty.\n   */\n  AUTOPLAY = 3,\n}\n\nexport interface PlaylistInitData {\n  /**\n   * The tracks of this playlist\n   */\n  tracks: Track[];\n  /**\n   * The playlist title\n   */\n  title: string;\n  /**\n   * The description\n   */\n  description: string;\n  /**\n   * The thumbnail\n   */\n  thumbnail: string;\n  /**\n   * The playlist type: `album` | `playlist`\n   */\n  type: 'album' | 'playlist';\n  /**\n   * The playlist source\n   */\n  source: TrackSource;\n  /**\n   * The playlist author\n   */\n  author: {\n    /**\n     * The author name\n     */\n    name: string;\n    /**\n     * The author url\n     */\n    url: string;\n  };\n  /**\n   * The playlist id\n   */\n  id: string;\n  /**\n   * The playlist url\n   */\n  url: string;\n  /**\n   * The raw playlist data\n   */\n  rawPlaylist?: any; // eslint-disable-line @typescript-eslint/no-explicit-any\n}\n\nexport interface TrackJSON {\n  /**\n   * The track id\n   */\n  id: string;\n  /**\n   * The track title\n   */\n  title: string;\n  /**\n   * The track description\n   */\n  description: string;\n  /**\n   * The track author\n   */\n  author: string;\n  /**\n   * The track url\n   */\n  url: string;\n  /**\n   * The track thumbnail\n   */\n  thumbnail: string;\n  /**\n   * The track duration\n   */\n  duration: string;\n  /**\n   * The track duration in ms\n   */\n  durationMS: number;\n  /**\n   * The track views\n   */\n  views: number;\n  /**\n   * The user id who requested this track\n   */\n  requestedBy: string;\n  /**\n   * The playlist info (if any)\n   */\n  playlist?: PlaylistJSON;\n}\n\nexport interface PlaylistJSON {\n  /**\n   * The playlist id\n   */\n  id: string;\n  /**\n   * The playlist url\n   */\n  url: string;\n  /**\n   * The playlist title\n   */\n  title: string;\n  /**\n   * The playlist description\n   */\n  description: string;\n  /**\n   * The thumbnail\n   */\n  thumbnail: string;\n  /**\n   * The playlist type: `album` | `playlist`\n   */\n  type: 'album' | 'playlist';\n  /**\n   * The track source\n   */\n  source: TrackSource;\n  /**\n   * The playlist author\n   */\n  author: {\n    /**\n     * The author name\n     */\n    name: string;\n    /**\n     * The author url\n     */\n    url: string;\n  };\n  /**\n   * The tracks data (if any)\n   */\n  tracks: TrackJSON[];\n}\n\nexport interface PlayerInitOptions {\n  /**\n   * The voice connection timeout\n   */\n  connectionTimeout?: number;\n  /**\n   * Time in ms to re-monitor event loop lag\n   */\n  lagMonitor?: number;\n  /**\n   * Prevent voice state handler from being overridden\n   */\n  lockVoiceStateHandler?: boolean;\n  /**\n   * List of extractors to disable querying metadata from\n   */\n  blockExtractors?: string[];\n  /**\n   * List of extractors to disable streaming from\n   */\n  blockStreamFrom?: string[];\n  /**\n   * Query cache provider\n   */\n  // eslint-disable-next-line @typescript-eslint/no-explicit-any\n  queryCache?: QueryCacheProvider<any> | null;\n  /**\n   * Use legacy version of ffmpeg\n   */\n  useLegacyFFmpeg?: boolean;\n  /**\n   * Set bridge provider\n   */\n  bridgeProvider?: BridgeProvider;\n  /**\n   * Skip ffmpeg process when possible\n   */\n  skipFFmpeg?: boolean;\n  /**\n   * The probe timeout in milliseconds. Defaults to 5000.\n   */\n  probeTimeout?: number;\n  /**\n   * Configure ffmpeg path\n   */\n  ffmpegPath?: string;\n  /**\n   * Whether to override the fallback context. Defaults to `true`.\n   */\n  overrideFallbackContext?: boolean;\n}\n", "import { User } from 'discord.js';\nimport { BaseExtractor } from '../extractors/BaseExtractor';\nimport { Player } from '../Player';\nimport { QueryExtractorSearch, QueryType, SearchQueryType } from '../types/types';\nimport { Playlist } from './Playlist';\nimport { Track } from './Track';\n\nexport interface SearchResultData {\n  query: string;\n  queryType?: SearchQueryType | QueryExtractorSearch | null;\n  extractor?: BaseExtractor | null;\n  playlist?: Playlist | null;\n  tracks?: Track[];\n  requestedBy?: User | null;\n}\n\nexport class SearchResult {\n  public constructor(public player: Player, private _data: SearchResultData) {\n    this._data.tracks?.forEach((track) => {\n      track.extractor ??= this._data.extractor || null;\n      track.requestedBy ??= _data.requestedBy || null;\n    });\n  }\n\n  public setQueryType(type: SearchQueryType | QueryExtractorSearch) {\n    this._data.queryType = type;\n    return this;\n  }\n\n  public setRequestedBy(user: User) {\n    this._data.requestedBy = user;\n    this._data.tracks?.forEach((track) => {\n      track.requestedBy = user;\n    });\n    return this;\n  }\n\n  public setExtractor(extractor: BaseExtractor) {\n    this._data.extractor = extractor;\n    this._data.tracks?.forEach((track) => {\n      track.extractor = extractor;\n    });\n    return this;\n  }\n\n  public setTracks(tracks: Track[]) {\n    this._data.tracks = tracks;\n    return this;\n  }\n\n  public setQuery(query: string) {\n    this._data.query = query;\n    return this;\n  }\n\n  public setPlaylist(playlist: Playlist) {\n    this._data.playlist = playlist;\n    return this;\n  }\n\n  /**\n   * The search query\n   */\n  public get query() {\n    return this._data.query;\n  }\n\n  /**\n   * The search query type\n   */\n  public get queryType() {\n    return this._data.queryType || QueryType.AUTO;\n  }\n\n  /**\n   * The extractor\n   */\n  public get extractor() {\n    return this._data.extractor || null;\n  }\n\n  /**\n   * Playlist result\n   */\n  public get playlist() {\n    return this._data.playlist;\n  }\n\n  /**\n   * Tracks result\n   */\n  public get tracks() {\n    return this._data.tracks || [];\n  }\n\n  /**\n   * Requested by\n   */\n  public get requestedBy() {\n    return this._data.requestedBy || null;\n  }\n\n  /**\n   * Re-execute this search\n   */\n  public async execute() {\n    return this.player.search(this.query, {\n      searchEngine: this.queryType,\n      requestedBy: this.requestedBy!,\n    });\n  }\n\n  /**\n   * If this search result is empty\n   */\n  public isEmpty() {\n    return !this.tracks.length;\n  }\n\n  /**\n   * If this search result has playlist\n   */\n  public hasPlaylist() {\n    return this.playlist != null;\n  }\n\n  /**\n   * If this search result has tracks\n   */\n  public hasTracks() {\n    return this.tracks.length > 0;\n  }\n\n  /**\n   * JSON representation of this search\n   */\n  public toJSON() {\n    return {\n      query: this.query,\n      queryType: this.queryType,\n      playlist: this.playlist?.toJSON(false) || null,\n      tracks: this.tracks.map((m) => m.toJSON(true)),\n      extractor: this.extractor?.identifier || null,\n      requestedBy: this.requestedBy?.toJSON() || null,\n    };\n  }\n}\n", "import { FiltersName } from '../types/types';\n\nconst bass = (g: number) => `bass=g=${g}:f=110:w=0.3`;\n\nexport class AudioFilters {\n  public constructor() {\n    return AudioFilters;\n  }\n\n  public static filters: Record<FiltersName, string> = {\n    bassboost_low: bass(15),\n    bassboost: bass(20),\n    bassboost_high: bass(30),\n    '8D': 'apulsator=hz=0.09',\n    vaporwave: 'aresample=48000,asetrate=48000*0.8',\n    nightcore: 'aresample=48000,asetrate=48000*1.25',\n    lofi: 'aresample=48000,asetrate=48000*0.9,extrastereo=m=2.5:c=disabled',\n    phaser: 'aphaser=in_gain=0.4',\n    tremolo: 'tremolo',\n    vibrato: 'vibrato=f=6.5',\n    reverse: 'areverse',\n    treble: 'treble=g=5',\n    normalizer2: 'dynaudnorm=g=101',\n    normalizer: 'acompressor',\n    surrounding: 'surround',\n    pulsator: 'apulsator=hz=1',\n    subboost: 'asubboost',\n    karaoke: 'stereotools=mlev=0.03',\n    flanger: 'flanger',\n    gate: 'agate',\n    haas: 'haas',\n    mcompand: 'mcompand',\n    mono: 'pan=mono|c0=.5*c0+.5*c1',\n    mstlr: 'stereotools=mode=ms>lr',\n    mstrr: 'stereotools=mode=ms>rr',\n    compressor: 'compand=points=-80/-105|-62/-80|-15.4/-15.4|0/-12|20/-7.6',\n    expander: 'compand=attacks=0:points=-80/-169|-54/-80|-49.5/-64.6|-41.1/-41.1|-25.8/-15|-10.8/-4.5|0/0|20/8.3',\n    softlimiter: 'compand=attacks=0:points=-80/-80|-12.4/-12.4|-6/-8|0/-6.8|20/-2.8',\n    chorus: 'chorus=0.7:0.9:55:0.4:0.25:2',\n    chorus2d: 'chorus=0.6:0.9:50|60:0.4|0.32:0.25|0.4:2|1.3',\n    chorus3d: 'chorus=0.5:0.9:50|60|40:0.4|0.32|0.3:0.25|0.4|0.3:2|2.3|1.3',\n    fadein: 'afade=t=in:ss=0:d=10',\n    dim: `afftfilt=\"'real=re * (1-clip((b/nb)*b,0,1))':imag='im * (1-clip((b/nb)*b,0,1))'\"`,\n    earrape: 'channelsplit,sidechaingate=level_in=64',\n    silenceremove: 'silenceremove=1:0:-50dB',\n  };\n\n  public static get<K extends FiltersName>(name: K) {\n    return this.filters[name] ?? name;\n  }\n\n  public static has<K extends FiltersName>(name: K) {\n    return name in this.filters;\n  }\n\n  public static *[Symbol.iterator](): IterableIterator<{ name: FiltersName; value: string }> {\n    for (const [k, v] of Object.entries(this.filters)) {\n      yield { name: k as FiltersName, value: v as string };\n    }\n  }\n\n  public static get names() {\n    return Object.keys(this.filters) as FiltersName[];\n  }\n\n  // @ts-ignore\n  public static get length() {\n    return this.names.length;\n  }\n\n  public static toString() {\n    return this.names.map((m) => (this as any)[m]).join(','); // eslint-disable-line @typescript-eslint/no-explicit-any\n  }\n\n  /**\n   * Create ffmpeg args from the specified filters name\n   * @param filter The filter name\n   * @returns\n   */\n  public static create<K extends FiltersName>(filters?: (K | string)[]) {\n    if (!filters || !Array.isArray(filters)) return this.toString();\n    return filters\n      .filter((predicate) => typeof predicate === 'string')\n      .map((m) => this.get(m as K))\n      .join(',');\n  }\n\n  /**\n   * Defines audio filter\n   * @param filterName The name of the filter\n   * @param value The ffmpeg args\n   */\n  public static define(filterName: string, value: string) {\n    this.filters[filterName as FiltersName] = value;\n  }\n\n  /**\n   * Defines multiple audio filters\n   * @param filtersArray Array of filters containing the filter name and ffmpeg args\n   */\n  public static defineBulk(filtersArray: { name: string; value: string }[]) {\n    filtersArray.forEach((arr) => this.define(arr.name, arr.value));\n  }\n}\n", "import { DefaultListener } from '@discord-player/utils';\nimport { ListenerSignature } from '@discord-player/utils';\nimport { EventEmitter } from '@discord-player/utils';\nimport { Util } from './Util';\n\nexport class PlayerEventsEmitter<L extends ListenerSignature<L> = DefaultListener> extends EventEmitter<L> {\n  #hasDebugger = false;\n  public constructor(public requiredEvents: Array<keyof L> = []) {\n    super();\n  }\n\n  public on<K extends keyof L>(name: K, listener: L[K]) {\n    if (name === 'debug') {\n      this.#hasDebugger = true;\n    }\n\n    return super.on(name, listener);\n  }\n\n  public once<K extends keyof L>(name: K, listener: L[K]) {\n    if (name === 'debug') {\n      this.#hasDebugger = true;\n    }\n\n    return super.once(name, listener);\n  }\n\n  public addListener<K extends keyof L>(name: K, listener: L[K]) {\n    if (name === 'debug') {\n      this.#hasDebugger = true;\n    }\n\n    return super.addListener(name, listener);\n  }\n\n  public off<K extends keyof L>(name: K, listener: L[K]) {\n    this.#hasDebugger = this.listenerCount('debug' as K) > 0;\n\n    return super.off(name, listener);\n  }\n\n  public removeListener<K extends keyof L>(name: K, listener: L[K]) {\n    this.#hasDebugger = this.listenerCount('debug' as K) > 0;\n\n    return super.removeListener(name, listener);\n  }\n\n  public removeAllListeners<K extends keyof L>(name?: K) {\n    this.#hasDebugger = this.listenerCount('debug' as K) > 0;\n\n    return super.removeAllListeners(name);\n  }\n\n  public emit<K extends keyof L>(name: K, ...args: Parameters<L[K]>) {\n    if (this.requiredEvents.includes(name) && !this.eventNames().includes(name)) {\n      // eslint-disable-next-line no-console\n      console.error(...args);\n      Util.warn(\n        `No event listener found for event \"${String(name)}\". Events ${this.requiredEvents\n          .map((m) => `\"${String(m)}\"`)\n          .join(', ')} must have event listeners.`,\n        'UnhandledEventsWarning',\n      );\n      return false;\n    }\n\n    return super.emit(name, ...args);\n  }\n\n  public get hasDebugger() {\n    return this.#hasDebugger;\n  }\n}\n", "import { User } from 'discord.js';\nimport { Readable } from 'stream';\nimport { Playlist } from '../fabric/Playlist';\nimport { Track } from '../fabric/Track';\nimport { PlayerEvents, SearchQueryType } from '../types/types';\nimport { ExtractorExecutionContext } from './ExtractorExecutionContext';\nimport type { RequestOptions } from 'http';\nimport { Exceptions } from '../errors';\nimport type { GuildQueueHistory } from '../queue';\n\nexport type ExtractorStreamable =\n  | Readable\n  | string\n  | {\n      $fmt: string;\n      stream: Readable;\n    };\n\nexport class BaseExtractor<T extends object = object> {\n  /**\n   * Identifier for this extractor\n   */\n  public static identifier = 'com.discord-player.extractor';\n\n  /**\n   * Priority of this extractor. Higher value means higher priority (will be executed first).\n   */\n  public priority = 1;\n\n  /**\n   * A list of query protocols that this extractor supports.\n   */\n  public protocols: string[] = [];\n\n  /**\n   * Handle bridge query creation\n   * @param track The track to build query for\n   */\n  public createBridgeQuery = (track: Track) => `${track.title} by ${track.author} official audio`;\n\n  /**\n   * Extractor constructor\n   * @param context Context that instantiated this extractor\n   * @param options Initialization options for this extractor\n   */\n  public constructor(public context: ExtractorExecutionContext, public options: T = <T>{}) {}\n\n  /**\n   * Identifier of this extractor\n   */\n  public get identifier() {\n    return (this.constructor as typeof BaseExtractor).identifier;\n  }\n\n  /**\n   * Reconfigures this extractor\n   * @param options The new options to apply\n   */\n  public async reconfigure(options: T) {\n    this.options = options;\n    await this.deactivate();\n    await this.activate();\n  }\n\n  /**\n   * This method will be executed when this extractor is activated\n   */\n  public async activate() {\n    // executed when this extractor is activated\n    return;\n  }\n\n  /**\n   * This method will be executed when this extractor is deactivated\n   */\n  public async deactivate() {\n    // executed when this extractor is deactivated\n    return;\n  }\n\n  /**\n   * Validate incoming query\n   * @param query The query to validate\n   */\n  public async validate(query: string, type?: SearchQueryType | null): Promise<boolean> {\n    void type;\n    return false;\n  }\n\n  /**\n   * Stream the given track\n   * @param info The track to stream\n   */\n  public async stream(info: Track): Promise<ExtractorStreamable> {\n    void info;\n    throw Exceptions.ERR_NOT_IMPLEMENTED(`${this.constructor.name}.stream()`);\n  }\n\n  /**\n   * Handle the given query\n   * @param query The query to handle\n   */\n  public async handle(query: string, context: ExtractorSearchContext): Promise<ExtractorInfo> {\n    void context;\n    throw Exceptions.ERR_NOT_IMPLEMENTED(`${this.constructor.name}.handle()`);\n  }\n\n  /**\n   * Get related tracks for the given track\n   * @param track The track source\n   */\n  public async getRelatedTracks(track: Track, history: GuildQueueHistory): Promise<ExtractorInfo> {\n    void track;\n    void history;\n    throw Exceptions.ERR_NOT_IMPLEMENTED(`${this.constructor.name}.getRelatedTracks()`);\n  }\n\n  /**\n   * A stream middleware to handle streams before passing it to the player\n   * @param stream The incoming stream\n   * @param next The next function\n   */\n  public handlePostStream(stream: Readable, next: NextFunction) {\n    return next(null, stream);\n  }\n\n  /**\n   * Dispatch an event to the player\n   * @param event The event to dispatch\n   * @param args The data to dispatch\n   */\n  public emit<K extends keyof PlayerEvents>(event: K, ...args: Parameters<PlayerEvents[K]>) {\n    return this.context.player.emit(event, ...args);\n  }\n\n  /**\n   * Create extractor response\n   * @param playlist The playlist\n   * @param tracks The track array\n   */\n  public createResponse(playlist?: Playlist | null, tracks: Track[] = playlist?.tracks || []): ExtractorInfo {\n    return { playlist: playlist || null, tracks };\n  }\n\n  /**\n   * Write debug message\n   * @param message The debug message\n   */\n  public debug(message: string) {\n    return this.context.player.debug(message);\n  }\n\n  /**\n   * A flag to indicate `Demuxable` stream support for `opus`/`ogg/opus`/`webm/opus` formats.\n   */\n  public get supportsDemux() {\n    return !!this.context.player.options.skipFFmpeg;\n  }\n\n  /**\n   * Handle stream extraction for another extractor\n   * @param track The track to bridge\n   * @param sourceExtractor The source extractor\n   */\n  public async bridge(track: Track, sourceExtractor: BaseExtractor | null): Promise<ExtractorStreamable | null> {\n    void sourceExtractor;\n    return null;\n  }\n}\n\nexport type NextFunction = (error?: Error | null, stream?: Readable) => void;\n\nexport interface ExtractorInfo {\n  playlist: Playlist | null;\n  tracks: Track[];\n}\n\nexport interface ExtractorSearchContext {\n  type?: SearchQueryType | null;\n  requestedBy?: User | null;\n  requestOptions?: RequestOptions;\n  protocol?: string | null;\n}\n", "import { Player } from '../Player';\nimport { Collection } from '@discord-player/utils';\nimport { BaseExtractor, ExtractorStreamable } from './BaseExtractor';\nimport { Util } from '../utils/Util';\nimport { PlayerEventsEmitter } from '../utils/PlayerEventsEmitter';\nimport { TypeUtil } from '../utils/TypeUtil';\nimport { Track } from '../fabric';\nimport { createContext } from '../hooks';\nimport { Exceptions } from '../errors';\n\nexport interface ExtractorSession {\n  id: string;\n  attemptedExtractors: Set<string>;\n  bridgeAttemptedExtractors: Set<string>;\n}\n\nexport interface ExtractorExecutionEvents {\n  /**\n   * Emitted when a extractor is registered\n   * @param context The context where extractor was registered\n   * @param extractor The extractor that was registered\n   */\n  registered: (context: ExtractorExecutionContext, extractor: BaseExtractor) => unknown;\n  /**\n   * Emitted when a extractor is unregistered\n   * @param context The context where extractor was unregistered\n   * @param extractor The extractor that was unregistered\n   */\n  unregistered: (context: ExtractorExecutionContext, extractor: BaseExtractor) => unknown;\n  /**\n   * Emitted when a extractor is activated\n   * @param context The context where this event occurred\n   * @param extractor The extractor which was activated\n   */\n  activate: (context: ExtractorExecutionContext, extractor: BaseExtractor) => unknown;\n  /**\n   * Emitted when a extractor is deactivated\n   * @param context The context where this event occurred\n   * @param extractor The extractor which was deactivated\n   */\n  deactivate: (context: ExtractorExecutionContext, extractor: BaseExtractor) => unknown;\n  /**\n   * Emitted when a extractor fails to activate/deactivate\n   * @param context The context where this event occurred\n   * @param extractor The extractor which was deactivated\n   */\n  error: (context: ExtractorExecutionContext, extractor: BaseExtractor, error: Error) => unknown;\n}\n\nexport class ExtractorExecutionContext extends PlayerEventsEmitter<ExtractorExecutionEvents> {\n  /**\n   * The extractors store\n   */\n  public store = new Collection<string, BaseExtractor>();\n\n  public readonly context = createContext<ExtractorSession>();\n\n  public constructor(public player: Player) {\n    super(['error']);\n  }\n\n  /**\n   * Get the current execution id\n   */\n  public getExecutionId(): string | null {\n    return this.context.consume()?.id ?? null;\n  }\n\n  /**\n   * Get the current execution context\n   */\n  public getContext() {\n    return this.context.consume() ?? null;\n  }\n\n  public async loadDefault() {\n    const sample = `\\timport { DefaultExtractors } from '@discord-player/extractor';\\n\\tawait player.extractors.loadMulti(DefaultExtractors);`;\n\n    throw new Error(\n      `extractors.loadDefault() is no longer supported. Use extractors.loadMulti instead. Example:\\n${sample}\\n`,\n    );\n  }\n\n  /**\n   * Load a bundle of extractors.\n   * @example import { DefaultExtractors } from '@discord-player/extractor';\n   *\n   * await player.extractors.loadMulti(DefaultExtractors);\n   */\n  public async loadMulti<\n    O extends object,\n    T extends (typeof BaseExtractor<O>)[],\n    R extends Record<T[number]['identifier'], ConstructorParameters<T[number]>[1]>,\n  >(bundle: T, options: R = {} as R) {\n    bundle.forEach((ext) => {\n      // @ts-ignore\n      this.register(ext, options?.[ext.identifier] || {});\n    });\n\n    return { success: true, error: null };\n  }\n\n  /**\n   * Validate if the given extractor is registered\n   * @param identifier The extractor identifier\n   */\n  public isRegistered(identifier: string) {\n    return this.store.has(identifier);\n  }\n\n  /**\n   * The size of registered extractors\n   */\n  public get size() {\n    return this.store.size;\n  }\n\n  /**\n   * Get single extractor\n   * @param identifier The extractor to get\n   */\n  public get(identifier: string) {\n    return this.store.get(identifier);\n  }\n\n  /**\n   * Register single extractor\n   * @param _extractor The extractor to register\n   * @param options Options supplied to the extractor\n   */\n  public async register<O extends object, T extends typeof BaseExtractor<O>>(\n    _extractor: T,\n    options: ConstructorParameters<T>['1'],\n  ): Promise<InstanceType<T> | null> {\n    if (typeof _extractor.identifier !== 'string' || this.store.has(_extractor.identifier)) return null;\n    const extractor = new _extractor(this, options);\n\n    // @ts-ignore\n    if (this.player.options.bridgeProvider) options.bridgeProvider ??= this.player.options.bridgeProvider;\n\n    try {\n      this.store.set(_extractor.identifier, extractor);\n      if (this.player.hasDebugger) this.player.debug(`${_extractor.identifier} extractor loaded!`);\n      this.emit('registered', this, extractor);\n      await extractor.activate();\n      if (this.player.hasDebugger) this.player.debug(`${_extractor.identifier} extractor activated!`);\n      this.emit('activate', this, extractor);\n      return extractor as unknown as InstanceType<T>;\n    } catch (e) {\n      this.store.delete(_extractor.identifier);\n      if (this.player.hasDebugger)\n        this.player.debug(`${_extractor.identifier} extractor failed to activate! Error: ${e}`);\n      this.emit('error', this, extractor, e as Error);\n      return null;\n    }\n  }\n\n  /**\n   * Unregister single extractor\n   * @param _extractor The extractor to unregister\n   */\n  public async unregister<K extends string | BaseExtractor>(_extractor: K) {\n    const extractor =\n      typeof _extractor === 'string' ? this.store.get(_extractor) : this.store.find((r) => r === _extractor);\n    if (!extractor) return;\n\n    try {\n      const key = extractor.identifier || this.store.findKey((e) => e === extractor)!;\n      this.store.delete(key);\n      if (this.player.hasDebugger) this.player.debug(`${extractor.identifier} extractor disabled!`);\n      this.emit('unregistered', this, extractor);\n      await extractor.deactivate();\n      if (this.player.hasDebugger) this.player.debug(`${extractor.identifier} extractor deactivated!`);\n      this.emit('deactivate', this, extractor);\n    } catch (e) {\n      if (this.player.hasDebugger) this.player.debug(`${extractor.identifier} extractor failed to deactivate!`);\n      this.emit('error', this, extractor, e as Error);\n    }\n  }\n\n  /**\n   * Unregister all extractors\n   */\n  public async unregisterAll() {\n    try {\n      await Promise.all(this.store.map((e) => this.unregister(e)));\n    } catch {\n      // do nothing\n    }\n  }\n\n  /**\n   * Run all the extractors\n   * @param fn The runner function\n   * @param filterBlocked Filter blocked extractors\n   */\n  public async run<T = unknown>(fn: ExtractorExecutionFN<T>, filterBlocked = true) {\n    const blocked = this.player.options.blockExtractors ?? [];\n\n    if (!this.store.size) {\n      Util.warn('Skipping extractors execution since zero extractors were registered', 'NoExtractors');\n      return;\n    }\n\n    // sort by priority so that extractors with higher priority are executed first\n    const extractors = this.store.sort((a, b) => b.priority - a.priority);\n\n    let err: Error | null = null,\n      lastExt: BaseExtractor | null = null;\n\n    for (const ext of extractors.values()) {\n      if (filterBlocked && blocked.some((e) => e === ext.identifier)) continue;\n      if (this.player.hasDebugger) this.player.debug(`Executing extractor ${ext.identifier}...`);\n      const result = await fn(ext).then(\n        (res) => {\n          return res;\n        },\n        (e) => {\n          if (this.player.hasDebugger) this.player.debug(`Extractor ${ext.identifier} failed with error: ${e}`);\n\n          return TypeUtil.isError(e) ? e : new Error(`${e}`);\n        },\n      );\n\n      lastExt = ext;\n\n      if (result && !TypeUtil.isError(result)) {\n        if (this.player.hasDebugger) this.player.debug(`Extractor ${ext.identifier} executed successfully!`);\n\n        return {\n          extractor: ext,\n          error: null,\n          result,\n        } as ExtractorExecutionResult<T>;\n      } else if (TypeUtil.isError(result)) {\n        err = result;\n      }\n    }\n\n    if (err)\n      return {\n        extractor: lastExt!,\n        error: err,\n        result: false,\n      } as ExtractorExecutionResult<false>;\n  }\n\n  /**\n   * Request bridge for a track\n   * @param track The track to request bridge for\n   * @param sourceExtractor The source extractor of the track\n   */\n  public async requestBridge(track: Track, sourceExtractor: BaseExtractor | null = track.extractor) {\n    const previouslyAttempted = this.getContext()?.bridgeAttemptedExtractors ?? new Set<string>();\n\n    const result = await this.run<ExtractorStreamable>(async (ext) => {\n      if (sourceExtractor && ext.identifier === sourceExtractor.identifier) return false;\n      if (previouslyAttempted.has(ext.identifier)) return false;\n\n      previouslyAttempted.add(ext.identifier);\n\n      const result = await ext.bridge(track, sourceExtractor);\n\n      if (!result) return false;\n\n      return result;\n    });\n\n    if (!result?.result)\n      throw Exceptions.ERR_BRIDGE_FAILED(\n        this.getExecutionId(),\n        result?.error?.stack || result?.error?.message || 'No extractors available to bridge',\n      );\n\n    track.bridgedExtractor = result.extractor;\n\n    return result;\n  }\n\n  /**\n   * Request bridge from the specified extractor\n   * @param track The track to request bridge for\n   * @param sourceExtractor The source extractor of the track\n   * @param targetExtractor The target extractor to bridge to\n   */\n  public async requestBridgeFrom(\n    track: Track,\n    sourceExtractor: BaseExtractor | null,\n    targetExtractor: ExtractorResolvable,\n  ) {\n    const target = this.resolve(targetExtractor);\n    if (!target) return null;\n    return target.bridge(track, sourceExtractor);\n  }\n\n  /**\n   * Check if extractor is disabled\n   */\n  public isDisabled(identifier: string) {\n    return this.player.options.blockExtractors?.includes(identifier) ?? false;\n  }\n\n  /**\n   * Check if extractor is enabled\n   */\n  public isEnabled(identifier: string) {\n    return !this.isDisabled(identifier);\n  }\n\n  /**\n   * Resolve extractor identifier\n   */\n  public resolveId(resolvable: ExtractorResolvable) {\n    return typeof resolvable === 'string' ? resolvable : resolvable.identifier;\n  }\n\n  /**\n   * Resolve extractor\n   */\n  public resolve(resolvable: ExtractorResolvable) {\n    return typeof resolvable === 'string' ? this.get(resolvable) : resolvable;\n  }\n}\n\nexport interface ExtractorExecutionResult<T = unknown> {\n  extractor: BaseExtractor;\n  error: Error | null;\n  result: T;\n}\n\nexport type ExtractorExecutionFN<T = unknown> = (extractor: BaseExtractor) => Promise<T | boolean>;\n\nexport type ExtractorResolvable = string | BaseExtractor;\n", "import { AsyncLocalStorage } from 'node:async_hooks';\n\n// eslint-disable-next-line @typescript-eslint/no-explicit-any\ntype unsafe = any;\n\n/**\n * The receiver function that will be called when the context is provided\n */\nexport type ContextReceiver<R> = () => R;\n\nexport class Context<T> {\n  private storage = new AsyncLocalStorage<T>();\n\n  public constructor(private defaultValue?: T) {}\n\n  /**\n   * Exit out of this context\n   */\n  public exit(scope: ContextReceiver<void>) {\n    this.storage.exit(scope);\n  }\n\n  /**\n   * Whether the context is lost\n   */\n  public get isLost() {\n    return this.storage.getStore() === undefined;\n  }\n\n  /**\n   * Get the current value of the context. If the context is lost and no default value is provided, undefined will be returned.\n   */\n  public consume(): T | undefined {\n    const data = this.storage.getStore();\n\n    if (data === undefined && this.defaultValue !== undefined) return this.defaultValue;\n\n    return data;\n  }\n\n  /**\n   * Run a function within the context of this provider\n   */\n  public provide<R = unsafe>(value: T, receiver: ContextReceiver<R>): R {\n    if (value === undefined) {\n      throw new Error('Context value may not be undefined');\n    }\n\n    if (typeof receiver !== 'function') {\n      throw new Error('Context receiver must be a function');\n    }\n\n    return this.storage.run(value, receiver);\n  }\n}\n\n/**\n * Create a new context. The default value is optional.\n * @param defaultValue The default value of the context\n * @example const userContext = createContext();\n *\n *  // the value to provide\n *  const user = {\n *   id: 1,\n *   name: 'John Doe'\n *  };\n *\n *  // provide the context value to the receiver\n *  context.provide(user, handler);\n *\n *  function handler() {\n *    // get the context value\n *    const { id, name } = useContext(context);\n *\n *    console.log(id, name); // 1, John Doe\n *  }\n */\nexport function createContext<T = unsafe>(defaultValue?: T): Context<T> {\n  return new Context(defaultValue);\n}\n\n/**\n * Get the current value of the context. If the context is lost and no default value is provided, undefined will be returned.\n * @param context The context to get the value from\n * @example const value = useContext(context);\n */\nexport function useContext<T = unsafe>(context: Context<T>): T | undefined {\n  return context.consume();\n}\n", "import { Collection } from '@discord-player/utils';\n\nexport const globalRegistry = new Collection<string, unknown>();\n", "import { globalRegistry } from './_container';\n\nexport function getGlobalRegistry() {\n  return globalRegistry;\n}\n", "import { Guild } from 'discord.js';\nimport { Player } from '../Player';\nimport { Exceptions } from '../errors';\nimport { createContext, useContext } from './context/async-context';\nimport { getGlobalRegistry } from '../utils/__internal__';\n\nexport interface HooksCtx {\n  guild: Guild;\n}\n\nexport const SUPER_CONTEXT = createContext<Player>();\n\nconst getFallbackContext = () => {\n  return getGlobalRegistry().get('@[player]') as Player | undefined;\n};\n\n/**\n * @private\n */\nexport function useHooksContext(hookName: string, mainOnly = false) {\n  let isFallback = false;\n\n  let player: Player | undefined;\n\n  if (!(player = SUPER_CONTEXT.consume())) {\n    player = getFallbackContext();\n    isFallback = true;\n  }\n\n  if (!player)\n    throw Exceptions.ERR_ILLEGAL_HOOK_INVOCATION(\n      'discord-player',\n      `Player context is not available, ${\n        isFallback\n          ? 'did you forget to initialize the player with `new Player(client)`?'\n          : 'is it being called inside <Player>.context.provide()?'\n      }`,\n    );\n\n  if (mainOnly) return { player, context: {} as HooksCtx, isFallback };\n\n  let context: HooksCtx | undefined;\n\n  if (!isFallback) {\n    context = useContext(player.context);\n    if (!context)\n      throw Exceptions.ERR_ILLEGAL_HOOK_INVOCATION(\n        hookName,\n        `${hookName} must be called inside a player context created by <Player>.context.provide()`,\n      );\n  } else {\n    context = {\n      get guild() {\n        throw Exceptions.ERR_ILLEGAL_HOOK_INVOCATION(\n          hookName,\n          `${hookName} must be called with an explicit guild argument when not inside a player context`,\n        );\n      },\n    } as unknown as HooksCtx;\n  }\n\n  return { context, player, isFallback };\n}\n", "import { GuildQueueHistory, NodeResolvable } from '../queue';\nimport { useHooksContext } from './common';\n\n/**\n * Fetch guild queue history\n * @param node guild queue node resolvable\n */\nexport function useHistory<Meta = unknown>(): GuildQueueHistory<Meta> | null;\nexport function useHistory<Meta = unknown>(node: NodeResolvable): GuildQueueHistory<Meta> | null;\nexport function useHistory<Meta = unknown>(node?: NodeResolvable): GuildQueueHistory<Meta> | null {\n  const { context, player } = useHooksContext('useHistory');\n\n  const queue = player.queues.get<Meta>(node ?? context.guild.id);\n  if (!queue) return null;\n\n  return queue.history;\n}\n", "import { GuildQueuePlayerNode, NodeResolvable } from '../queue';\nimport { useHooksContext } from './common';\n\n/**\n * Fetch guild queue player node\n * @param node Guild queue node resolvable\n */\nexport function usePlayer<Meta = unknown>(): GuildQueuePlayerNode<Meta> | null;\nexport function usePlayer<Meta = unknown>(node: NodeResolvable): GuildQueuePlayerNode<Meta> | null;\nexport function usePlayer<Meta = unknown>(node?: NodeResolvable): GuildQueuePlayerNode<Meta> | null {\n  const { context, player } = useHooksContext('usePlayer');\n  const queue = player.queues.get<Meta>(node ?? context.guild.id);\n  if (!queue) return null;\n\n  return queue.node;\n}\n", "import { GuildQueue, NodeResolvable } from '../queue';\nimport { useHooksContext } from './common';\n\n/**\n * Fetch guild queue.\n * @param node Guild queue node resolvable. Defaults to inferred guild from context.\n */\nexport function useQueue<Meta = unknown>(): GuildQueue<Meta> | null;\nexport function useQueue<Meta = unknown>(node: NodeResolvable): GuildQueue<Meta> | null;\nexport function useQueue<Meta = unknown>(node?: NodeResolvable): GuildQueue<Meta> | null {\n  const { context, player } = useHooksContext('useQueue');\n  const queue = player.queues.resolve<Meta>(node ?? context.guild.id);\n  if (!queue) return null;\n\n  return queue;\n}\n", "import { useHooksContext } from './common';\n\n/**\n * Fetch main player instance\n */\nexport function useMainPlayer() {\n  const { player } = useHooksContext('useMainPlayer', true);\n\n  return player;\n}\n", "import { NodeResolvable } from '../queue';\nimport { TypeUtil } from '../utils/TypeUtil';\nimport { useHooksContext } from './common';\n\nexport type SetterFN<T, P> = (previous: P) => T;\nexport type MetadataDispatch<T> = readonly [() => T, (metadata: T | SetterFN<T, T>) => void];\n\n/**\n * Fetch or manipulate guild queue metadata\n * @param node Guild queue node resolvable\n */\nexport function useMetadata<T = unknown>(): MetadataDispatch<T>;\nexport function useMetadata<T = unknown>(node: NodeResolvable): MetadataDispatch<T>;\nexport function useMetadata<T = unknown>(node?: NodeResolvable): MetadataDispatch<T> {\n  const { context, player } = useHooksContext('useMetadata');\n  const queue = player.queues.get<T>(node ?? context.guild.id);\n  const setter = (metadata: T | SetterFN<T, T>) => {\n    if (queue) {\n      if (TypeUtil.isFunction(metadata)) return queue.setMetadata(metadata(queue.metadata));\n      return queue.setMetadata(metadata);\n    }\n  };\n\n  const getter = () => {\n    return queue?.metadata as T;\n  };\n\n  return [getter, setter] as const;\n}\n", "import { Track } from '../fabric';\nimport { NodeResolvable, PlayerTimestamp } from '../queue';\nimport { useHooksContext } from './common';\n\nexport interface TimelineDispatcherOptions {\n  ignoreFilters: boolean;\n  node: NodeResolvable;\n}\n\nexport interface GuildQueueTimeline {\n  readonly timestamp: PlayerTimestamp;\n  readonly volume: number;\n  readonly paused: boolean;\n  readonly track: Track<unknown> | null;\n  pause(): boolean;\n  resume(): boolean;\n  setVolume(vol: number): boolean;\n  setPosition(time: number): Promise<boolean>;\n}\n\n/**\n * Fetch or manipulate current track\n * @param options Options for timeline dispatcher\n */\nexport function useTimeline(): GuildQueueTimeline | null;\nexport function useTimeline(options: Partial<TimelineDispatcherOptions>): GuildQueueTimeline | null;\nexport function useTimeline(options?: Partial<TimelineDispatcherOptions>): GuildQueueTimeline | null {\n  const { context, player } = useHooksContext('useTimeline');\n  const queue = player.queues.get(options?.node ?? context.guild.id);\n  if (!queue) return null;\n\n  const timeline = Object.preventExtensions({\n    get timestamp() {\n      return queue.node.getTimestamp(options?.ignoreFilters)!;\n    },\n    get volume() {\n      return queue.node.volume;\n    },\n    get paused() {\n      return queue.node.isPaused();\n    },\n    get track() {\n      return queue.currentTrack;\n    },\n    pause() {\n      return queue.node.pause();\n    },\n    resume() {\n      return queue.node.resume();\n    },\n    setVolume(vol: number) {\n      return queue.node.setVolume(vol);\n    },\n    async setPosition(time: number) {\n      return queue.node.seek(time);\n    },\n  });\n\n  return timeline;\n}\n", "import { OnAfterCreateStreamHandler } from '../../queue';\nimport { getGlobalRegistry } from '../../utils/__internal__';\n\n/**\n * Global onAfterCreateStream handler\n * @param handler The handler callback\n */\nexport function onAfterCreateStream(handler: OnAfterCreateStreamHandler) {\n  getGlobalRegistry().set('@[onAfterCreateStream]', handler);\n}\n", "import { OnBeforeCreateStreamHandler } from '../../queue';\nimport { getGlobalRegistry } from '../../utils/__internal__';\n\n/**\n * Global onBeforeCreateStream handler\n * @param handler The handler callback\n */\nexport function onBeforeCreateStream(handler: OnBeforeCreateStreamHandler) {\n  getGlobalRegistry().set('@[onBeforeCreateStream]', handler);\n}\n", "import { NodeResolvable } from '../queue';\nimport { TypeUtil } from '../utils/TypeUtil';\nimport { useHooksContext } from './common';\n\ntype SetterFN = (previous: number) => number;\ntype VolumeDispatch = readonly [() => number, (volume: number | SetterFN) => boolean | undefined];\n\n/**\n * Fetch or manipulate player volume\n * @param node Guild queue node resolvable\n */\nexport function useVolume(): VolumeDispatch;\nexport function useVolume(node: NodeResolvable): VolumeDispatch;\nexport function useVolume(node?: NodeResolvable): VolumeDispatch {\n  const { context, player } = useHooksContext('useVolume');\n  const queue = player.queues.get(node ?? context.guild.id);\n  const setter = (volume: number | SetterFN) => {\n    if (queue) {\n      if (TypeUtil.isFunction(volume)) return queue.node.setVolume(volume(queue.node.volume));\n      return queue.node.setVolume(volume);\n    }\n  };\n\n  const getter = () => {\n    return queue?.node.volume as number;\n  };\n\n  return [getter, setter] as const;\n}\n", "import { EqualizerBand, PCMFilters, BiquadFilters } from '@discord-player/equalizer';\nimport { Collection, QueueStrategy } from '@discord-player/utils';\nimport { GuildResolvable } from 'discord.js';\nimport { Player } from '../Player';\nimport { GuildQueue, OnAfterCreateStreamHandler, OnBeforeCreateStreamHandler } from './GuildQueue';\nimport { FiltersName, QueueRepeatMode } from '../types/types';\nimport { getGlobalRegistry } from '../utils/__internal__';\nimport { Exceptions } from '../errors';\n\nexport interface GuildNodeCreateOptions<T = unknown> {\n  strategy?: QueueStrategy;\n  volume?: number;\n  equalizer?: EqualizerBand[];\n  a_filter?: PCMFilters[];\n  biquad?: BiquadFilters;\n  resampler?: number;\n  disableHistory?: boolean;\n  onBeforeCreateStream?: OnBeforeCreateStreamHandler;\n  onAfterCreateStream?: OnAfterCreateStreamHandler;\n  repeatMode?: QueueRepeatMode;\n  pauseOnEmpty?: boolean;\n  leaveOnEmpty?: boolean;\n  leaveOnEmptyCooldown?: number;\n  leaveOnEnd?: boolean;\n  leaveOnEndCooldown?: number;\n  leaveOnStop?: boolean;\n  leaveOnStopCooldown?: number;\n  metadata?: T | null;\n  selfDeaf?: boolean;\n  connectionTimeout?: number;\n  defaultFFmpegFilters?: FiltersName[];\n  bufferingTimeout?: number;\n  noEmitInsert?: boolean;\n  maxSize?: number;\n  maxHistorySize?: number;\n  preferBridgedMetadata?: boolean;\n  disableVolume?: boolean;\n  disableEqualizer?: boolean;\n  disableFilterer?: boolean;\n  disableBiquad?: boolean;\n  disableResampler?: boolean;\n  disableFallbackStream?: boolean;\n}\n\nexport type NodeResolvable = GuildQueue | GuildResolvable;\n\nexport class GuildNodeManager<Meta = unknown> {\n  public cache = new Collection<string, GuildQueue>();\n  public constructor(public player: Player) {}\n\n  /**\n   * Create guild queue if it does not exist\n   * @param guild The guild which will be the owner of the queue\n   * @param options Queue initializer options\n   */\n  public create<T = Meta>(guild: GuildResolvable, options: GuildNodeCreateOptions<T> = {}): GuildQueue<T> {\n    const server = this.player.client.guilds.resolve(guild);\n    if (!server) {\n      throw Exceptions.ERR_NO_GUILD('Invalid or unknown guild');\n    }\n\n    if (this.cache.has(server.id)) {\n      return this.cache.get(server.id) as GuildQueue<T>;\n    }\n\n    options.strategy ??= 'FIFO';\n    options.volume ??= 100;\n    options.equalizer ??= [];\n    options.a_filter ??= [];\n    options.disableHistory ??= false;\n    options.leaveOnEmpty ??= true;\n    options.leaveOnEmptyCooldown ??= 0;\n    options.leaveOnEnd ??= true;\n    options.leaveOnEndCooldown ??= 0;\n    options.leaveOnStop ??= true;\n    options.leaveOnStopCooldown ??= 0;\n    options.resampler ??= 48000;\n    options.selfDeaf ??= true;\n    options.connectionTimeout ??= this.player.options.connectionTimeout;\n    options.bufferingTimeout ??= 1000;\n    options.maxSize ??= Infinity;\n    options.maxHistorySize ??= Infinity;\n    options.preferBridgedMetadata ??= true;\n    options.pauseOnEmpty ??= true;\n    // todo(twlite): maybe disable these by default?\n    options.disableBiquad ??= false;\n    options.disableEqualizer ??= false;\n    options.disableFilterer ??= false;\n    options.disableVolume ??= false;\n    options.disableResampler ??= true;\n    options.disableFallbackStream ??= false;\n\n    if (getGlobalRegistry().has('@[onBeforeCreateStream]') && !options.onBeforeCreateStream) {\n      options.onBeforeCreateStream = getGlobalRegistry().get('@[onBeforeCreateStream]') as OnBeforeCreateStreamHandler;\n    }\n\n    if (getGlobalRegistry().has('@[onAfterCreateStream]') && !options.onAfterCreateStream) {\n      options.onAfterCreateStream = getGlobalRegistry().get('@[onAfterCreateStream]') as OnAfterCreateStreamHandler;\n    }\n\n    const queue = new GuildQueue<T>(this.player, {\n      guild: server,\n      queueStrategy: options.strategy,\n      volume: options.volume,\n      equalizer: options.equalizer,\n      filterer: options.a_filter,\n      biquad: options.biquad,\n      resampler: options.resampler,\n      disableHistory: options.disableHistory,\n      onBeforeCreateStream: options.onBeforeCreateStream,\n      onAfterCreateStream: options.onAfterCreateStream,\n      repeatMode: options.repeatMode,\n      leaveOnEmpty: options.leaveOnEmpty,\n      leaveOnEmptyCooldown: options.leaveOnEmptyCooldown,\n      leaveOnEnd: options.leaveOnEnd,\n      leaveOnEndCooldown: options.leaveOnEndCooldown,\n      leaveOnStop: options.leaveOnStop,\n      leaveOnStopCooldown: options.leaveOnStopCooldown,\n      metadata: options.metadata,\n      connectionTimeout: options.connectionTimeout ?? 120_000,\n      selfDeaf: options.selfDeaf,\n      ffmpegFilters: options.defaultFFmpegFilters ?? [],\n      bufferingTimeout: options.bufferingTimeout,\n      noEmitInsert: options.noEmitInsert ?? false,\n      preferBridgedMetadata: options.preferBridgedMetadata,\n      maxHistorySize: options.maxHistorySize,\n      maxSize: options.maxSize,\n      pauseOnEmpty: options.pauseOnEmpty,\n      disableBiquad: options.disableBiquad,\n      disableEqualizer: options.disableEqualizer,\n      disableFilterer: options.disableFilterer,\n      disableResampler: options.disableResampler,\n      disableVolume: options.disableVolume,\n      disableFallbackStream: options.disableFallbackStream,\n    });\n\n    this.cache.set(server.id, queue);\n\n    return queue;\n  }\n\n  /**\n   * Get existing queue\n   * @param node Queue resolvable\n   */\n  public get<T = Meta>(node: NodeResolvable) {\n    const queue = this.resolve(node);\n    if (!queue) return null;\n\n    return (this.cache.get(queue.id) as GuildQueue<T>) || null;\n  }\n\n  /**\n   * Check if a queue exists\n   * @param node Queue resolvable\n   */\n  public has(node: NodeResolvable) {\n    const id = node instanceof GuildQueue ? node.id : this.player.client.guilds.resolveId(node)!;\n    return this.cache.has(id);\n  }\n\n  /**\n   * Delete queue\n   * @param node Queue resolvable\n   */\n  public delete(node: NodeResolvable) {\n    const queue = this.resolve(node);\n    if (!queue) {\n      throw Exceptions.ERR_NO_GUILD_QUEUE('Cannot delete non-existing queue');\n    }\n\n    queue.setTransitioning(true);\n    queue.node.stop(true);\n    // @ts-ignore\n    queue.connection?.removeAllListeners();\n    queue.dispatcher?.removeAllListeners();\n    queue.dispatcher?.disconnect();\n    queue.timeouts.forEach((tm) => clearTimeout(tm));\n    queue.history.clear();\n    queue.tracks.clear();\n\n    return this.cache.delete(queue.id);\n  }\n\n  /**\n   * Resolve queue\n   * @param node Queue resolvable\n   */\n  public resolve<T = Meta>(node: NodeResolvable): GuildQueue<T> | undefined {\n    if (node instanceof GuildQueue) {\n      return node as GuildQueue<T>;\n    }\n\n    return this.cache.get(this.player.client.guilds.resolveId(node)!) as GuildQueue<T>;\n  }\n\n  /**\n   * Resolve queue id\n   * @param node Queue resolvable\n   */\n  public resolveId(node: NodeResolvable) {\n    const q = this.resolve(node);\n    return q?.id || null;\n  }\n}\n", "import { Player, PlayerNodeInitializerOptions, TrackLike } from '../Player';\nimport { ChannelType, Guild, GuildVoiceChannelResolvable, VoiceBasedChannel, VoiceState } from 'discord.js';\nimport { Collection, Queue, QueueStrategy } from '@discord-player/utils';\nimport { BiquadFilters, EqualizerBand, PCMFilters } from '@discord-player/equalizer';\nimport { Track, TrackResolvable } from '../fabric/Track';\nimport { StreamDispatcher } from '../VoiceInterface/StreamDispatcher';\nimport { type AudioPlayer, AudioResource, StreamType, VoiceConnection, VoiceConnectionStatus } from 'discord-voip';\nimport { Util, VALIDATE_QUEUE_CAP } from '../utils/Util';\nimport { Playlist } from '../fabric/Playlist';\nimport { GuildQueueHistory } from './GuildQueueHistory';\nimport { GuildQueuePlayerNode, StreamConfig } from './GuildQueuePlayerNode';\nimport { GuildQueueAudioFilters } from './GuildQueueAudioFilters';\nimport { Readable } from 'stream';\nimport { FiltersName, QueueRepeatMode, SearchQueryType } from '../types/types';\nimport { setTimeout } from 'timers';\nimport { GuildQueueStatistics } from './GuildQueueStatistics';\nimport { TypeUtil } from '../utils/TypeUtil';\nimport { AsyncQueue } from '../utils/AsyncQueue';\nimport { Exceptions } from '../errors';\nimport { SyncedLyricsProvider } from './SyncedLyricsProvider';\nimport { LrcGetResult, LrcSearchResult } from '../lrclib/LrcLib';\n\nexport interface GuildNodeInit<Meta = unknown> {\n  guild: Guild;\n  queueStrategy: QueueStrategy;\n  equalizer: EqualizerBand[] | boolean;\n  volume: number | boolean;\n  biquad: BiquadFilters | boolean | undefined;\n  resampler: number | boolean;\n  filterer: PCMFilters[] | boolean;\n  ffmpegFilters: FiltersName[];\n  disableHistory: boolean;\n  onBeforeCreateStream?: OnBeforeCreateStreamHandler;\n  onAfterCreateStream?: OnAfterCreateStreamHandler;\n  repeatMode?: QueueRepeatMode;\n  leaveOnEmpty: boolean;\n  leaveOnEmptyCooldown: number;\n  leaveOnEnd: boolean;\n  leaveOnEndCooldown: number;\n  leaveOnStop: boolean;\n  leaveOnStopCooldown: number;\n  connectionTimeout: number;\n  selfDeaf?: boolean;\n  metadata?: Meta | null;\n  bufferingTimeout: number;\n  noEmitInsert: boolean;\n  maxSize?: number;\n  maxHistorySize?: number;\n  preferBridgedMetadata: boolean;\n  pauseOnEmpty?: boolean;\n  disableVolume: boolean;\n  disableEqualizer: boolean;\n  disableFilterer: boolean;\n  disableBiquad: boolean;\n  disableResampler: boolean;\n  disableFallbackStream: boolean;\n}\n\nexport interface VoiceConnectConfig {\n  deaf?: boolean;\n  timeout?: number;\n  group?: string;\n  audioPlayer?: AudioPlayer;\n}\n\nexport interface PostProcessedResult {\n  stream: Readable;\n  type: StreamType;\n}\n\nexport type OnBeforeCreateStreamHandler = (\n  track: Track,\n  queryType: SearchQueryType,\n  queue: GuildQueue,\n) => Promise<Readable | null>;\nexport type OnAfterCreateStreamHandler = (stream: Readable, queue: GuildQueue) => Promise<PostProcessedResult | null>;\n\nexport type PlayerTriggeredReason = 'filters' | 'normal';\n\nexport const GuildQueueEvent = {\n  /**\n   * Emitted when audio track is added to the queue\n   */\n  AudioTrackAdd: 'audioTrackAdd',\n  /**\n   * Emitted when audio tracks were added to the queue\n   */\n  AudioTracksAdd: 'audioTracksAdd',\n  /**\n   * Emitted when audio track is removed from the queue\n   */\n  AudioTrackRemove: 'audioTrackRemove',\n  /**\n   * Emitted when audio tracks are removed from the queue\n   */\n  AudioTracksRemove: 'audioTracksRemove',\n  /**\n   * Emitted when a connection is created\n   */\n  Connection: 'connection',\n  /**\n   * Emitted when a voice connection is destroyed\n   */\n  ConnectionDestroyed: 'connectionDestroyed',\n  /**\n   * Emitted when the bot is disconnected from the channel\n   */\n  Disconnect: 'disconnect',\n  /**\n   * Emitted when the queue sends a debug info\n   */\n  Debug: 'debug',\n  /**\n   * Emitted when the queue encounters error\n   */\n  Error: 'error',\n  /**\n   * Emitted when the voice channel is empty\n   */\n  EmptyChannel: 'emptyChannel',\n  /**\n   * Emitted when the queue is empty\n   */\n  EmptyQueue: 'emptyQueue',\n  /**\n   * Emitted when the audio player starts streaming audio track\n   */\n  PlayerStart: 'playerStart',\n  /**\n   * Emitted when the audio player errors while streaming audio track\n   */\n  PlayerError: 'playerError',\n  /**\n   * Emitted when the audio player finishes streaming audio track\n   */\n  PlayerFinish: 'playerFinish',\n  /**\n   * Emitted when the audio player skips current track\n   */\n  PlayerSkip: 'playerSkip',\n  /**\n   * Emitted when the audio player is triggered\n   */\n  PlayerTrigger: 'playerTrigger',\n  /**\n   * Emitted when the voice state is updated. Consuming this event may disable default voice state update handler if `Player.isVoiceStateHandlerLocked()` returns `false`.\n   */\n  VoiceStateUpdate: 'voiceStateUpdate',\n  /**\n   * Emitted when volume is updated\n   */\n  VolumeChange: 'volumeChange',\n  /**\n   * Emitted when player is paused\n   */\n  PlayerPause: 'playerPause',\n  /**\n   * Emitted when player is resumed\n   */\n  PlayerResume: 'playerResume',\n  /**\n   * Biquad Filters Update\n   */\n  BiquadFiltersUpdate: 'biquadFiltersUpdate',\n  /**\n   * Equalizer Update\n   */\n  EqualizerUpdate: 'equalizerUpdate',\n  /**\n   * DSP update\n   */\n  DSPUpdate: 'dspUpdate',\n  /**\n   * Audio Filters Update\n   */\n  AudioFiltersUpdate: 'audioFiltersUpdate',\n  /**\n   * Audio player will play next track\n   */\n  WillPlayTrack: 'willPlayTrack',\n  /**\n   * Emitted when a voice channel is repopulated\n   */\n  ChannelPopulate: 'channelPopulate',\n  /**\n   * Emitted when a queue is successfully created\n   */\n  QueueCreate: 'queueCreate',\n  /**\n   * Emitted when a queue is deleted\n   */\n  QueueDelete: 'queueDelete',\n  /**\n   * Emitted when a queue is trying to add similar track for autoplay\n   */\n  WillAutoPlay: 'willAutoPlay',\n} as const;\n\nexport type GuildQueueEvent = (typeof GuildQueueEvent)[keyof typeof GuildQueueEvent];\n\nexport enum TrackSkipReason {\n  NoStream = 'ERR_NO_STREAM',\n  Manual = 'MANUAL',\n  SEEK_OVER_THRESHOLD = 'SEEK_OVER_THRESHOLD',\n  Jump = 'JUMPED_TO_ANOTHER_TRACK',\n  SkipTo = 'SKIP_TO_ANOTHER_TRACK',\n  HistoryNext = 'HISTORY_NEXT_TRACK',\n}\n\n// eslint-disable-next-line @typescript-eslint/no-explicit-any\nexport interface GuildQueueEvents<Meta = any> {\n  /**\n   * Emitted when audio track is added to the queue\n   * @param queue The queue where this event occurred\n   * @param track The track\n   */\n  [GuildQueueEvent.AudioTrackAdd]: (queue: GuildQueue<Meta>, track: Track) => unknown;\n  /**\n   * Emitted when audio tracks were added to the queue\n   * @param queue The queue where this event occurred\n   * @param tracks The tracks array\n   */\n  [GuildQueueEvent.AudioTracksAdd]: (queue: GuildQueue<Meta>, track: Track[]) => unknown;\n  /**\n   * Emitted when audio track is removed from the queue\n   * @param queue The queue where this event occurred\n   * @param track The track\n   */\n  [GuildQueueEvent.AudioTrackRemove]: (queue: GuildQueue<Meta>, track: Track) => unknown;\n  /**\n   * Emitted when audio tracks are removed from the queue\n   * @param queue The queue where this event occurred\n   * @param track The track\n   */\n  [GuildQueueEvent.AudioTracksRemove]: (queue: GuildQueue<Meta>, track: Track[]) => unknown;\n  /**\n   * Emitted when a connection is created\n   * @param queue The queue where this event occurred\n   */\n  [GuildQueueEvent.Connection]: (queue: GuildQueue<Meta>) => unknown;\n  /**\n   * Emitted when a connection is destroyed\n   * @param queue The queue where this event occurred\n   */\n  [GuildQueueEvent.ConnectionDestroyed]: (queue: GuildQueue<Meta>) => unknown;\n  /**\n   * Emitted when the bot is disconnected from the channel\n   * @param queue The queue where this event occurred\n   */\n  [GuildQueueEvent.Disconnect]: (queue: GuildQueue<Meta>) => unknown;\n  /**\n   * Emitted when the queue sends a debug info\n   * @param queue The queue where this event occurred\n   * @param message The debug message\n   */\n  [GuildQueueEvent.Debug]: (queue: GuildQueue<Meta>, message: string) => unknown;\n  /**\n   * Emitted when the queue encounters error\n   * @param queue The queue where this event occurred\n   * @param error The error\n   */\n  [GuildQueueEvent.Error]: (queue: GuildQueue<Meta>, error: Error) => unknown;\n  /**\n   * Emitted when the voice channel is empty\n   * @param queue The queue where this event occurred\n   */\n  [GuildQueueEvent.EmptyChannel]: (queue: GuildQueue<Meta>) => unknown;\n  /**\n   * Emitted when the queue is empty\n   * @param queue The queue where this event occurred\n   */\n  [GuildQueueEvent.EmptyQueue]: (queue: GuildQueue<Meta>) => unknown;\n  /**\n   * Emitted when the audio player starts streaming audio track\n   * @param queue The queue where this event occurred\n   * @param track The track that is being streamed\n   */\n  [GuildQueueEvent.PlayerStart]: (queue: GuildQueue<Meta>, track: Track) => unknown;\n  /**\n   * Emitted when the audio player errors while streaming audio track\n   * @param queue The queue where this event occurred\n   * @param error The error\n   * @param track The track that is being streamed\n   */\n  [GuildQueueEvent.PlayerError]: (queue: GuildQueue<Meta>, error: Error, track: Track) => unknown;\n  /**\n   * Emitted when the audio player finishes streaming audio track\n   * @param queue The queue where this event occurred\n   * @param track The track that was being streamed\n   */\n  [GuildQueueEvent.PlayerFinish]: (queue: GuildQueue<Meta>, track: Track) => unknown;\n  /**\n   * Emitted when the audio player skips current track\n   * @param queue The queue where this event occurred\n   * @param track The track that was skipped\n   * @param reason The reason for skipping\n   * @param description The description for skipping\n   */\n  [GuildQueueEvent.PlayerSkip]: (\n    queue: GuildQueue<Meta>,\n    track: Track,\n    reason: TrackSkipReason,\n    description: string,\n  ) => unknown;\n  /**\n   * Emitted when the audio player is triggered\n   * @param queue The queue where this event occurred\n   * @param track The track which was played in this event\n   */\n  [GuildQueueEvent.PlayerTrigger]: (queue: GuildQueue<Meta>, track: Track, reason: PlayerTriggeredReason) => unknown;\n  /**\n   * Emitted when the voice state is updated. Consuming this event may disable default voice state update handler if `Player.isVoiceStateHandlerLocked()` returns `false`.\n   * @param queue The queue where this event occurred\n   * @param oldState The old voice state\n   * @param newState The new voice state\n   */\n  [GuildQueueEvent.VoiceStateUpdate]: (queue: GuildQueue<Meta>, oldState: VoiceState, newState: VoiceState) => unknown;\n  /**\n   * Emitted when audio player is paused\n   * @param queue The queue where this event occurred\n   */\n  [GuildQueueEvent.PlayerPause]: (queue: GuildQueue<Meta>) => unknown;\n  /**\n   * Emitted when audio player is resumed\n   * @param queue The queue where this event occurred\n   */\n  [GuildQueueEvent.PlayerResume]: (queue: GuildQueue<Meta>) => unknown;\n  /**\n   * Emitted when audio player's volume is changed\n   * @param queue The queue where this event occurred\n   * @param oldVolume The old volume\n   * @param newVolume The updated volume\n   */\n  [GuildQueueEvent.VolumeChange]: (queue: GuildQueue<Meta>, oldVolume: number, newVolume: number) => unknown;\n  /**\n   * Emitted when equalizer config is updated\n   * @param queue The queue where this event occurred\n   * @param oldFilters Old filters\n   * @param newFilters New filters\n   */\n  [GuildQueueEvent.EqualizerUpdate]: (\n    queue: GuildQueue<Meta>,\n    oldFilters: EqualizerBand[],\n    newFilters: EqualizerBand[],\n  ) => unknown;\n  /**\n   * Emitted when biquad filters is updated\n   * @param queue The queue where this event occurred\n   * @param oldFilters Old filters\n   * @param newFilters New filters\n   */\n  [GuildQueueEvent.BiquadFiltersUpdate]: (\n    queue: GuildQueue<Meta>,\n    oldFilters: BiquadFilters | null,\n    newFilters: BiquadFilters | null,\n  ) => unknown;\n  /**\n   * Emitted when dsp filters is updated\n   * @param queue The queue where this event occurred\n   * @param oldFilters Old filters\n   * @param newFilters New filters\n   */\n  [GuildQueueEvent.DSPUpdate]: (queue: GuildQueue<Meta>, oldFilters: PCMFilters[], newFilters: PCMFilters[]) => unknown;\n  /**\n   * Emitted when ffmpeg audio filters is updated\n   * @param queue The queue where this event occurred\n   * @param oldFilters Old filters\n   * @param newFilters New filters\n   */\n  [GuildQueueEvent.AudioFiltersUpdate]: (\n    queue: GuildQueue<Meta>,\n    oldFilters: FiltersName[],\n    newFilters: FiltersName[],\n  ) => unknown;\n\n  /**\n   * Emitted before streaming an audio track. This event can be used to modify stream config before playing a track.\n   * Listening to this event will pause the execution of audio player until `done()` is invoked.\n   * @param queue The queue where this event occurred\n   * @param track The track that will be streamed\n   * @param config Configurations for streaming\n   * @param done Done callback\n   */\n  [GuildQueueEvent.WillPlayTrack]: (\n    queue: GuildQueue<Meta>,\n    track: Track<unknown>,\n    config: StreamConfig,\n    done: () => void,\n  ) => unknown;\n  /**\n   * Emitted when a voice channel is populated\n   * @param queue The queue where this event occurred\n   */\n  [GuildQueueEvent.ChannelPopulate]: (queue: GuildQueue<Meta>) => unknown;\n  /**\n   * Emitted when a queue is successfully created\n   * @param queue The queue where this event occurred\n   */\n  [GuildQueueEvent.QueueCreate]: (queue: GuildQueue<Meta>) => unknown;\n  /**\n   * Emitted when a queue is successfully deleted\n   * @param queue The queue where this event occurred\n   */\n  [GuildQueueEvent.QueueDelete]: (queue: GuildQueue<Meta>) => unknown;\n  /**\n   * Emitted when a queue is trying to add similar track for autoplay\n   * @param queue The queue where this event occurred\n   * @param tracks The similar tracks that were found\n   * @param done Done callback\n   */\n  [GuildQueueEvent.WillAutoPlay]: (\n    queue: GuildQueue<Meta>,\n    tracks: Track[],\n    done: (track: Track | null) => void,\n  ) => unknown;\n}\n\nexport class GuildQueue<Meta = unknown> {\n  #transitioning = false;\n  #deleted = false;\n  #shuffle = false;\n  private __current: Track | null = null;\n  public tracks: Queue<Track>;\n  public history = new GuildQueueHistory<Meta>(this);\n  public dispatcher: StreamDispatcher | null = null;\n  public node = new GuildQueuePlayerNode<Meta>(this);\n  public filters = new GuildQueueAudioFilters<Meta>(this);\n  public onBeforeCreateStream: OnBeforeCreateStreamHandler = async () => null;\n  public onAfterCreateStream: OnAfterCreateStreamHandler = async (stream) => ({\n    stream,\n    type: StreamType.Raw,\n  });\n  public repeatMode = QueueRepeatMode.OFF;\n  public timeouts = new Collection<string, NodeJS.Timeout>();\n  public stats = new GuildQueueStatistics<Meta>(this);\n  public tasksQueue = new AsyncQueue();\n  public syncedLyricsProvider = new SyncedLyricsProvider(this);\n\n  public constructor(public player: Player, public options: GuildNodeInit<Meta>) {\n    this.tracks = new Queue<Track>(options.queueStrategy);\n    if (TypeUtil.isFunction(options.onBeforeCreateStream)) this.onBeforeCreateStream = options.onBeforeCreateStream;\n    if (TypeUtil.isFunction(options.onAfterCreateStream)) this.onAfterCreateStream = options.onAfterCreateStream;\n    if (!TypeUtil.isNullish(options.repeatMode)) this.repeatMode = options.repeatMode;\n\n    options.selfDeaf ??= true;\n    options.maxSize ??= Infinity;\n    options.maxHistorySize ??= Infinity;\n    options.pauseOnEmpty ??= true;\n\n    if (!TypeUtil.isNullish(this.options.biquad) && !TypeUtil.isBoolean(this.options.biquad)) {\n      this.filters._lastFiltersCache.biquad = this.options.biquad;\n    }\n\n    if (Array.isArray(this.options.equalizer)) {\n      this.filters._lastFiltersCache.equalizer = this.options.equalizer;\n    }\n\n    if (Array.isArray(this.options.filterer)) {\n      this.filters._lastFiltersCache.filters = this.options.filterer;\n    }\n\n    if (TypeUtil.isNumber(this.options.resampler)) {\n      this.filters._lastFiltersCache.sampleRate = this.options.resampler;\n    }\n\n    if (TypeUtil.isArray(this.options.ffmpegFilters)) {\n      this.filters.ffmpeg.setDefaults(this.options.ffmpegFilters);\n    }\n\n    if (!TypeUtil.isNumber(options.maxSize)) {\n      throw Exceptions.ERR_INVALID_ARG_TYPE('[GuildNodeInit.maxSize]', 'number', typeof options.maxSize);\n    }\n\n    if (!TypeUtil.isNumber(options.maxHistorySize)) {\n      throw Exceptions.ERR_INVALID_ARG_TYPE('[GuildNodeInit.maxHistorySize]', 'number', typeof options.maxHistorySize);\n    }\n\n    if (options.maxSize < 1) options.maxSize = Infinity;\n    if (options.maxHistorySize < 1) options.maxHistorySize = Infinity;\n\n    if (this.hasDebugger)\n      this.debug(`GuildQueue initialized for guild ${this.options.guild.name} (ID: ${this.options.guild.id})`);\n    this.emit(GuildQueueEvent.QueueCreate, this);\n  }\n\n  /**\n   * Estimated duration of this queue in ms\n   */\n  public get estimatedDuration() {\n    return this.tracks.store.reduce((a, c) => a + c.durationMS, 0);\n  }\n\n  /**\n   * Formatted duration of this queue\n   */\n  public get durationFormatted() {\n    return Util.buildTimeCode(Util.parseMS(this.estimatedDuration));\n  }\n\n  /**\n   * The sync lyrics provider for this queue.\n   * @example const lyrics = await player.lyrics.search({ q: 'Alan Walker Faded' });\n   * const syncedLyrics = queue.syncedLyrics(lyrics[0]);\n   * console.log(syncedLyrics.at(10_000));\n   * // subscribe to lyrics change\n   * const unsubscribe = syncedLyrics.onChange((lyrics, timestamp) => {\n   *    console.log(lyrics, timestamp);\n   * });\n   * // unsubscribe from lyrics change\n   * unsubscribe(); // or\n   * syncedLyrics.unsubscribe();\n   */\n  public syncedLyrics(lyrics: LrcGetResult | LrcSearchResult) {\n    this.syncedLyricsProvider.load(lyrics?.syncedLyrics ?? '');\n    return this.syncedLyricsProvider;\n  }\n\n  /**\n   * Write a debug message to this queue\n   * @param m The message to write\n   */\n  public debug(m: string) {\n    this.emit(GuildQueueEvent.Debug, this, m);\n  }\n\n  /**\n   * The metadata of this queue\n   */\n  public get metadata() {\n    return this.options.metadata!;\n  }\n\n  public set metadata(m: Meta) {\n    this.options.metadata = m;\n  }\n\n  /**\n   * Set metadata for this queue\n   * @param m Metadata to set\n   */\n  public setMetadata(m: Meta) {\n    this.options.metadata = m;\n  }\n\n  /**\n   * Indicates current track of this queue\n   */\n  public get currentTrack() {\n    return this.dispatcher?.audioResource?.metadata || this.__current;\n  }\n\n  /**\n   * Indicates if this queue was deleted previously\n   */\n  public get deleted() {\n    return this.#deleted;\n  }\n\n  /**\n   * The voice channel of this queue\n   */\n  public get channel() {\n    return this.dispatcher?.channel || null;\n  }\n\n  public set channel(c: VoiceBasedChannel | null) {\n    if (this.dispatcher) {\n      if (c) {\n        this.dispatcher.channel = c;\n      } else {\n        this.delete();\n      }\n    }\n  }\n\n  /**\n   * The voice connection of this queue\n   */\n  public get connection() {\n    return this.dispatcher?.voiceConnection || null;\n  }\n\n  /**\n   * The guild this queue belongs to\n   */\n  public get guild() {\n    return this.options.guild;\n  }\n\n  /**\n   * The id of this queue\n   */\n  public get id() {\n    return this.guild.id;\n  }\n\n  /**\n   * Set transition mode for this queue\n   * @param state The state to set\n   */\n  public setTransitioning(state: boolean) {\n    this.#transitioning = state;\n  }\n\n  /**\n   * if this queue is currently under transition mode\n   */\n  public isTransitioning() {\n    return this.#transitioning;\n  }\n\n  /**\n   * Set repeat mode for this queue\n   * @param mode The repeat mode to apply\n   */\n  public setRepeatMode(mode: QueueRepeatMode) {\n    this.repeatMode = mode;\n  }\n\n  /**\n   * Max size of this queue\n   */\n  public get maxSize() {\n    return this.options.maxSize ?? Infinity;\n  }\n\n  /**\n   * Max size of this queue\n   */\n  public getMaxSize() {\n    return this.maxSize;\n  }\n\n  /**\n   * Gets the size of the queue\n   */\n  public get size() {\n    return this.tracks.size;\n  }\n\n  /**\n   * The size of this queue\n   */\n  public getSize() {\n    return this.size;\n  }\n\n  /**\n   * Max history size of this queue\n   */\n  public get maxHistorySize() {\n    return this.options.maxHistorySize ?? Infinity;\n  }\n\n  /**\n   * Max history size of this queue\n   */\n  public getMaxHistorySize() {\n    return this.maxHistorySize;\n  }\n\n  /**\n   * Set max history size for this queue\n   * @param size The size to set\n   */\n  public setMaxHistorySize(size: number) {\n    if (!TypeUtil.isNumber(size)) {\n      throw Exceptions.ERR_INVALID_ARG_TYPE('size', 'number', typeof size);\n    }\n\n    if (size < 1) size = Infinity;\n\n    this.options.maxHistorySize = size;\n  }\n\n  /**\n   * Set max size for this queue\n   * @param size The size to set\n   */\n  public setMaxSize(size: number) {\n    if (!TypeUtil.isNumber(size)) {\n      throw Exceptions.ERR_INVALID_ARG_TYPE('size', 'number', typeof size);\n    }\n\n    if (size < 1) size = Infinity;\n\n    this.options.maxSize = size;\n  }\n\n  /**\n   * Clear this queue\n   */\n  public clear() {\n    this.tracks.clear();\n    this.history.clear();\n  }\n\n  /**\n   * Check if this queue has no tracks left in it\n   */\n  public isEmpty() {\n    return this.tracks.size < 1;\n  }\n\n  /**\n   * Check if this queue is full\n   */\n  public isFull() {\n    return this.tracks.size >= this.maxSize;\n  }\n\n  /**\n   * Get queue capacity\n   */\n  public getCapacity() {\n    if (this.isFull()) return 0;\n    const cap = this.maxSize - this.size;\n    return cap;\n  }\n\n  /**\n   * Check if this queue currently holds active audio resource\n   */\n  public isPlaying() {\n    return this.dispatcher?.audioResource != null && !this.dispatcher.audioResource.ended;\n  }\n\n  /**\n   * Add track to the queue. This will emit `audioTracksAdd` when multiple tracks are added, otherwise `audioTrackAdd`.\n   * @param track Track or playlist or array of tracks to add\n   */\n  public addTrack(track: Track | Track[] | Playlist) {\n    const toAdd = track instanceof Playlist ? track.tracks : track;\n    const isMulti = Array.isArray(toAdd);\n\n    VALIDATE_QUEUE_CAP(this, toAdd);\n\n    this.tracks.add(toAdd);\n\n    if (isMulti) {\n      this.emit(GuildQueueEvent.AudioTracksAdd, this, toAdd);\n    } else {\n      this.emit(GuildQueueEvent.AudioTrackAdd, this, toAdd);\n    }\n  }\n\n  /**\n   * Remove a track from queue\n   * @param track The track to remove\n   */\n  public removeTrack(track: TrackResolvable) {\n    return this.node.remove(track);\n  }\n\n  /**\n   * Inserts the track to the given index\n   * @param track The track to insert\n   * @param index The index to insert the track at (defaults to 0)\n   */\n  public insertTrack(track: Track, index = 0): void {\n    return this.node.insert(track, index);\n  }\n\n  /**\n   * Moves a track in the queue\n   * @param from The track to move\n   * @param to The position to move to\n   */\n  public moveTrack(track: TrackResolvable, index = 0): void {\n    return this.node.move(track, index);\n  }\n\n  /**\n   * Copy a track in the queue\n   * @param from The track to clone\n   * @param to The position to clone at\n   */\n  public copyTrack(track: TrackResolvable, index = 0): void {\n    return this.node.copy(track, index);\n  }\n\n  /**\n   * Swap two tracks in the queue\n   * @param src The first track to swap\n   * @param dest The second track to swap\n   */\n  public swapTracks(src: TrackResolvable, dest: TrackResolvable): void {\n    return this.node.swap(src, dest);\n  }\n\n  /**\n   * Create stream dispatcher from the given connection\n   * @param connection The connection to use\n   */\n  public createDispatcher(\n    connection: VoiceConnection,\n    options: Pick<VoiceConnectConfig, 'audioPlayer' | 'timeout'> = {},\n  ) {\n    if (connection.state.status === VoiceConnectionStatus.Destroyed) {\n      throw Exceptions.ERR_VOICE_CONNECTION_DESTROYED();\n    }\n\n    const channel = this.player.client.channels.cache.get(connection.joinConfig.channelId!);\n    if (!channel) throw Exceptions.ERR_NO_VOICE_CHANNEL();\n    if (!channel.isVoiceBased())\n      throw Exceptions.ERR_INVALID_ARG_TYPE(\n        'channel',\n        `VoiceBasedChannel (type ${ChannelType.GuildVoice}/${ChannelType.GuildStageVoice})`,\n        String(channel?.type),\n      );\n\n    if (this.dispatcher) {\n      this.#removeListeners(this.dispatcher);\n      this.dispatcher.destroy();\n      this.dispatcher = null;\n    }\n\n    this.dispatcher = new StreamDispatcher(\n      connection,\n      channel,\n      this,\n      options.timeout ?? this.options.connectionTimeout,\n      options.audioPlayer,\n    );\n  }\n\n  /**\n   * Connect to a voice channel\n   * @param channelResolvable The voice channel to connect to\n   * @param options Join config\n   */\n  public async connect(channelResolvable: GuildVoiceChannelResolvable, options: VoiceConnectConfig = {}) {\n    const channel = this.player.client.channels.resolve(channelResolvable);\n    if (!channel || !channel.isVoiceBased()) {\n      throw Exceptions.ERR_INVALID_ARG_TYPE(\n        'channel',\n        `VoiceBasedChannel (type ${ChannelType.GuildVoice}/${ChannelType.GuildStageVoice})`,\n        String(channel?.type),\n      );\n    }\n\n    if (this.hasDebugger)\n      this.debug(\n        `Connecting to ${channel.type === ChannelType.GuildStageVoice ? 'stage' : 'voice'} channel ${\n          channel.name\n        } (ID: ${channel.id})`,\n      );\n\n    if (this.dispatcher && channel.id !== this.dispatcher.channel.id) {\n      if (this.hasDebugger) this.debug('Destroying old connection');\n      this.#removeListeners(this.dispatcher);\n      this.dispatcher.destroy();\n      this.dispatcher = null;\n    }\n\n    this.dispatcher = await this.player.voiceUtils.connect(channel, {\n      deaf: options.deaf ?? this.options.selfDeaf ?? true,\n      maxTime: options?.timeout ?? this.options.connectionTimeout ?? 120_000,\n      queue: this,\n      audioPlayer: options?.audioPlayer,\n      group: options.group ?? this.player.client.user?.id,\n    });\n\n    this.emit(GuildQueueEvent.Connection, this);\n\n    if (this.channel!.type === ChannelType.GuildStageVoice) {\n      await this.channel!.guild.members.me!.voice.setSuppressed(false).catch(async () => {\n        return await this.channel!.guild.members.me!.voice.setRequestToSpeak(true).catch(Util.noop);\n      });\n    }\n\n    this.#attachListeners(this.dispatcher);\n\n    return this;\n  }\n\n  /**\n   * Enable shuffle mode for this queue\n   * @param dynamic Whether to shuffle the queue dynamically. Defaults to `true`.\n   * Dynamic shuffling will shuffle the queue when the current track ends, without mutating the queue.\n   * If set to `false`, the queue will be shuffled immediately in-place, which cannot be undone.\n   */\n  public enableShuffle(dynamic = true) {\n    if (!dynamic) {\n      this.tracks.shuffle();\n      return true;\n    }\n\n    this.#shuffle = true;\n    return true;\n  }\n\n  /**\n   * Disable shuffle mode for this queue.\n   */\n  public disableShuffle() {\n    this.#shuffle = false;\n    return true;\n  }\n\n  /**\n   * Toggle shuffle mode for this queue.\n   * @param dynamic Whether to shuffle the queue dynamically. Defaults to `true`.\n   * @returns Whether shuffle is enabled or disabled.\n   */\n  public toggleShuffle(dynamic = true) {\n    if (dynamic) {\n      this.#shuffle = !this.#shuffle;\n      return this.#shuffle;\n    } else {\n      this.tracks.shuffle();\n      return true;\n    }\n  }\n\n  /**\n   * Whether shuffle mode is enabled for this queue.\n   */\n  public get isShuffling() {\n    return this.#shuffle;\n  }\n\n  /**\n   * The voice connection latency of this queue\n   */\n  public get ping() {\n    return this.connection?.ping.udp ?? -1;\n  }\n\n  /**\n   * Delete this queue\n   */\n  public delete() {\n    if (this.player.nodes.delete(this.id)) {\n      this.#deleted = true;\n      this.player.events.emit(GuildQueueEvent.QueueDelete, this);\n      this.node.tasksQueue.cancelAll();\n      this.tasksQueue.cancelAll();\n    }\n  }\n\n  /**\n   * Revives this queue\n   * @returns\n   */\n  public revive() {\n    if (!this.deleted || this.player.nodes.has(this.id)) return;\n    this.#deleted = false;\n    this.setTransitioning(false);\n    this.player.nodes.cache.set(this.id, this);\n    this.player.events.emit(GuildQueueEvent.QueueCreate, this);\n  }\n\n  /**\n   * Set self deaf\n   * @param mode On/Off state\n   * @param reason Reason\n   */\n  public setSelfDeaf(mode?: boolean, reason?: string) {\n    return this.guild.members.me!.voice.setDeaf(mode, reason);\n  }\n\n  /**\n   * Set self mute\n   * @param mode On/Off state\n   * @param reason Reason\n   */\n  public setSelfMute(mode?: boolean, reason?: string) {\n    return this.guild.members.me!.voice.setMute(mode, reason);\n  }\n\n  /**\n   * Play a track in this queue\n   * @param track The track to be played\n   * @param options Player node initialization options\n   */\n  public async play(track: TrackLike, options?: PlayerNodeInitializerOptions<Meta>) {\n    if (!this.channel) throw Exceptions.ERR_NO_VOICE_CONNECTION();\n\n    return this.player.play(this.channel, track, options);\n  }\n\n  /**\n   * Emit an event on this queue\n   * @param event The event to emit\n   * @param args The args for the event\n   */\n  public emit<K extends keyof GuildQueueEvents<Meta>>(\n    event: K,\n    ...args: Parameters<GuildQueueEvents<Meta>[K]>\n  ): boolean {\n    if (this.deleted) return false;\n    return this.player.events.emit(event, ...args);\n  }\n\n  #attachListeners(dispatcher: StreamDispatcher) {\n    dispatcher.on('error', (e) => this.emit(GuildQueueEvent.Error, this, e));\n    dispatcher.on('debug', (m) => this.hasDebugger && this.emit(GuildQueueEvent.Debug, this, m));\n    dispatcher.on('finish', (r) => this.#performFinish(r));\n    dispatcher.on('start', (r) => this.#performStart(r));\n    dispatcher.on('destroyed', () => {\n      this.#removeListeners(dispatcher);\n      this.dispatcher = null;\n    });\n    dispatcher.on('dsp', (f) => {\n      if (!Object.is(this.filters._lastFiltersCache.filters, f)) {\n        this.emit(GuildQueueEvent.DSPUpdate, this, this.filters._lastFiltersCache.filters, f);\n      }\n      this.filters._lastFiltersCache.filters = f;\n    });\n    dispatcher.on('biquad', (f) => {\n      if (this.filters._lastFiltersCache.biquad !== f) {\n        this.emit(GuildQueueEvent.BiquadFiltersUpdate, this, this.filters._lastFiltersCache.biquad, f);\n      }\n      this.filters._lastFiltersCache.biquad = f;\n    });\n    dispatcher.on('eqBands', (f) => {\n      if (!Object.is(f, this.filters._lastFiltersCache.equalizer)) {\n        this.emit(GuildQueueEvent.EqualizerUpdate, this, this.filters._lastFiltersCache.equalizer, f);\n      }\n      this.filters._lastFiltersCache.equalizer = f;\n    });\n    dispatcher.on('volume', (f) => {\n      if (this.filters._lastFiltersCache.volume !== f)\n        this.emit(GuildQueueEvent.VolumeChange, this, this.filters._lastFiltersCache.volume, f);\n      this.filters._lastFiltersCache.volume = f;\n    });\n  }\n\n  public get hasDebugger() {\n    return this.player.events.hasDebugger;\n  }\n\n  #removeListeners<T extends { removeAllListeners: () => unknown }>(target: T) {\n    target.removeAllListeners();\n  }\n\n  #performStart(resource?: AudioResource<Track>) {\n    const track = resource?.metadata || this.currentTrack;\n    const reason = this.isTransitioning() ? 'filters' : 'normal';\n\n    if (this.hasDebugger)\n      this.debug(\n        `Player triggered for Track ${JSON.stringify({\n          title: track?.title,\n          reason,\n        })}`,\n      );\n\n    this.emit(GuildQueueEvent.PlayerTrigger, this, track!, reason);\n    if (track && !this.isTransitioning()) this.emit(GuildQueueEvent.PlayerStart, this, track);\n    this.setTransitioning(false);\n  }\n\n  #getNextTrack() {\n    if (!this.isShuffling) {\n      return this.tracks.dispatch();\n    }\n\n    const store = this.tracks.store;\n\n    if (!store.length) return;\n\n    const track = Util.randomChoice(store);\n\n    this.tracks.removeOne((t) => {\n      return t.id === track.id;\n    });\n\n    return track;\n  }\n\n  #performFinish(resource?: AudioResource<Track>) {\n    const track = resource?.metadata || this.currentTrack;\n\n    if (this.hasDebugger)\n      this.debug(\n        `Track ${JSON.stringify({\n          title: track?.title,\n          isTransitionMode: this.isTransitioning(),\n        })} was marked as finished`,\n      );\n\n    if (!this.isTransitioning()) {\n      this.syncedLyricsProvider.unsubscribe();\n      this.syncedLyricsProvider.lyrics.clear();\n      if (this.hasDebugger)\n        this.debug('Adding track to history and emitting finish event since transition mode is disabled...');\n      if (track) {\n        this.history.push(track);\n        this.node.resetProgress();\n        this.emit(GuildQueueEvent.PlayerFinish, this, track);\n      }\n      if (this.#deleted) return this.#emitEnd();\n      if (this.tracks.size < 1 && this.repeatMode === QueueRepeatMode.OFF) {\n        if (this.hasDebugger)\n          this.debug('No more tracks left in the queue to play and repeat mode is off, initiating #emitEnd()');\n        this.#emitEnd();\n      } else {\n        if (this.repeatMode === QueueRepeatMode.TRACK) {\n          if (this.hasDebugger) this.debug('Repeat mode is set to track, repeating last track from the history...');\n          this.__current = this.history.tracks.dispatch() || track;\n          return this.node.play(this.__current!, { queue: false });\n        }\n        if (this.repeatMode === QueueRepeatMode.QUEUE) {\n          if (this.hasDebugger)\n            this.debug('Repeat mode is set to queue, moving last track from the history to current queue...');\n          const next = this.history.tracks.dispatch() || track;\n          if (next) this.tracks.add(next);\n        }\n        if (!this.tracks.size && track) {\n          if (this.repeatMode === QueueRepeatMode.AUTOPLAY) {\n            if (this.hasDebugger) this.debug('Repeat mode is set to autoplay, initiating autoplay handler...');\n            this.#handleAutoplay(track);\n            return;\n          }\n        } else {\n          if (this.hasDebugger) this.debug('Initializing next track of the queue...');\n          this.__current = this.#getNextTrack()!;\n          this.node.play(this.__current, {\n            queue: false,\n          });\n        }\n      }\n    }\n  }\n\n  #emitEnd() {\n    this.__current = null;\n    this.emit(GuildQueueEvent.EmptyQueue, this);\n    if (this.options.leaveOnEnd) {\n      const tm: NodeJS.Timeout = setTimeout(() => {\n        if (this.isPlaying()) return clearTimeout(tm);\n        this.dispatcher?.disconnect();\n      }, this.options.leaveOnEndCooldown).unref();\n    }\n  }\n\n  async #handleAutoplay(track: Track) {\n    try {\n      if (this.hasDebugger)\n        this.debug(\n          `Autoplay >> Finding related tracks for Track ${track.title} (${track.url}) [ext:${\n            track.extractor?.identifier || 'N/A'\n          }]`,\n        );\n      const tracks =\n        (await track.extractor?.getRelatedTracks(track, this.history))?.tracks ||\n        (\n          await this.player.extractors.run(async (ext) => {\n            if (this.hasDebugger) this.debug(`Autoplay >> Querying extractor ${ext.identifier}`);\n            const res = await ext.getRelatedTracks(track, this.history);\n            if (!res.tracks.length) {\n              if (this.hasDebugger) this.debug(`Autoplay >> Extractor ${ext.identifier} failed to provide results.`);\n              return false;\n            }\n\n            if (this.hasDebugger) this.debug(`Autoplay >> Extractor ${ext.identifier} successfully returned results.`);\n\n            return res.tracks;\n          })\n        )?.result ||\n        [];\n\n      let resolver: (track: Track | null) => void = Util.noop;\n      const donePromise = new Promise<Track | null>((resolve) => (resolver = resolve));\n\n      const success = this.emit(GuildQueueEvent.WillAutoPlay, this, tracks, resolver!);\n\n      // prevent dangling promise\n      if (!success) {\n        resolver(\n          tracks.length\n            ? (() => {\n                const unique = tracks.filter((tr) => !this.history.tracks.find((t) => t.url === tr.url));\n                return unique?.[0] ?? Util.randomChoice(tracks.slice(0, 5));\n              })()\n            : null,\n        );\n      }\n\n      const nextTrack = await donePromise;\n\n      if (!nextTrack) {\n        if (this.hasDebugger) this.debug('Autoplay >> No track was found, initiating #emitEnd()');\n        throw 'No track was found';\n      }\n\n      await this.node.play(nextTrack, {\n        queue: false,\n        seek: 0,\n        transitionMode: false,\n      });\n    } catch {\n      return this.#emitEnd();\n    }\n  }\n}\n", "import {\n  AudioPlayer,\n  AudioPlayerError,\n  AudioPlayerStatus,\n  AudioResource,\n  createAudioPlayer,\n  createAudioResource,\n  entersState,\n  StreamType,\n  VoiceConnection,\n  VoiceConnectionStatus,\n  VoiceConnectionDisconnectReason,\n} from 'discord-voip';\nimport { StageChannel, VoiceChannel } from 'discord.js';\nimport type { Readable } from 'stream';\nimport { EventEmitter } from '@discord-player/utils';\nimport { Track } from '../fabric/Track';\nimport { Util } from '../utils/Util';\nimport { EqualizerBand, BiquadFilters, PCMFilters, FiltersChain } from '@discord-player/equalizer';\nimport { GuildQueue, GuildQueueEvent, PostProcessedResult } from '../queue';\nimport { Exceptions } from '../errors';\n\nexport interface CreateStreamOps {\n  type?: StreamType;\n  // eslint-disable-next-line @typescript-eslint/no-explicit-any\n  data?: any;\n  disableVolume?: boolean;\n  disableEqualizer?: boolean;\n  disableBiquad?: boolean;\n  eq?: EqualizerBand[];\n  biquadFilter?: BiquadFilters;\n  disableFilters?: boolean;\n  defaultFilters?: PCMFilters[];\n  volume?: number;\n  disableResampler?: boolean;\n  sampleRate?: number;\n  skipFFmpeg?: boolean;\n}\n\nexport interface VoiceEvents {\n  /* eslint-disable @typescript-eslint/no-explicit-any */\n  error: (error: AudioPlayerError) => any;\n  debug: (message: string) => any;\n  start: (resource: AudioResource<Track>) => any;\n  finish: (resource: AudioResource<Track>) => any;\n  dsp: (filters: PCMFilters[]) => any;\n  eqBands: (filters: EqualizerBand[]) => any;\n  sampleRate: (filters: number) => any;\n  biquad: (filters: BiquadFilters) => any;\n  volume: (volume: number) => any;\n  destroyed: () => any;\n  /* eslint-enable @typescript-eslint/no-explicit-any */\n}\n\nclass StreamDispatcher extends EventEmitter<VoiceEvents> {\n  public voiceConnection: VoiceConnection;\n  public audioPlayer: AudioPlayer;\n  public channel: VoiceChannel | StageChannel;\n  public audioResource?: AudioResource<Track> | null;\n  public dsp = new FiltersChain();\n\n  /**\n   * Creates new connection object\n   * @param {VoiceConnection} connection The connection\n   * @param {VoiceChannel|StageChannel} channel The connected channel\n   * @private\n   */\n  constructor(\n    connection: VoiceConnection,\n    channel: VoiceChannel | StageChannel,\n    public queue: GuildQueue,\n    public readonly connectionTimeout: number = 20000,\n    audioPlayer?: AudioPlayer,\n  ) {\n    super();\n\n    /**\n     * The voice connection\n     * @type {VoiceConnection}\n     */\n    this.voiceConnection = connection;\n\n    /**\n     * The audio player\n     * @type {AudioPlayer}\n     */\n    this.audioPlayer =\n      audioPlayer ||\n      createAudioPlayer({\n        debug: this.queue.hasDebugger,\n      });\n\n    /**\n     * The voice channel\n     * @type {VoiceChannel|StageChannel}\n     */\n    this.channel = channel;\n\n    this.voiceConnection.on('debug', (m) => void this.emit('debug', m));\n    this.voiceConnection.on('error', (error) => void this.emit('error', error as AudioPlayerError));\n    this.audioPlayer.on('debug', (m) => void this.emit('debug', m));\n    this.audioPlayer.on('error', (error) => void this.emit('error', error));\n\n    this.dsp.onUpdate = () => {\n      if (!this.dsp) return;\n      if (this.dsp.filters?.filters) this.emit('dsp', this.dsp.filters?.filters);\n      if (this.dsp.biquad?.filters) this.emit('biquad', this.dsp.biquad?.filters);\n      if (this.dsp.equalizer) this.emit('eqBands', this.dsp.equalizer.getEQ());\n      if (this.dsp.volume) this.emit('volume', this.dsp.volume.volume);\n      if (this.dsp.resampler) this.emit('sampleRate', this.dsp.resampler.targetSampleRate);\n    };\n\n    this.dsp.onError = (e) => this.emit('error', e as AudioPlayerError);\n\n    this.voiceConnection\n      .on(VoiceConnectionStatus.Disconnected, async (oldState, newState) => {\n        if (newState.reason === VoiceConnectionDisconnectReason.Manual) {\n          this.destroy();\n          return;\n        }\n\n        if (newState.reason === VoiceConnectionDisconnectReason.WebSocketClose && newState.closeCode === 4014) {\n          try {\n            await entersState(this.voiceConnection, VoiceConnectionStatus.Connecting, this.connectionTimeout);\n          } catch {\n            try {\n              if (this.voiceConnection.state.status !== VoiceConnectionStatus.Destroyed) this.destroy();\n            } catch (err) {\n              this.emit('error', err as AudioPlayerError);\n            }\n          }\n        } else if (this.voiceConnection.rejoinAttempts < 5) {\n          await Util.wait((this.voiceConnection.rejoinAttempts + 1) * 5000);\n          this.voiceConnection.rejoin();\n        } else {\n          try {\n            if (this.voiceConnection.state.status !== VoiceConnectionStatus.Destroyed) this.destroy();\n          } catch (err) {\n            this.emit('error', err as AudioPlayerError);\n          }\n        }\n      })\n      .on(VoiceConnectionStatus.Destroyed, () => {\n        this.end();\n        this.queue.emit(GuildQueueEvent.ConnectionDestroyed, this.queue);\n      });\n\n    this.audioPlayer.on('stateChange', (oldState, newState) => {\n      if (oldState.status !== AudioPlayerStatus.Paused && newState.status === AudioPlayerStatus.Paused) {\n        this.queue.emit(GuildQueueEvent.PlayerPause, this.queue);\n      }\n\n      if (oldState.status === AudioPlayerStatus.Paused && newState.status !== AudioPlayerStatus.Paused) {\n        this.queue.emit(GuildQueueEvent.PlayerResume, this.queue);\n      }\n\n      if (newState.status === AudioPlayerStatus.Playing) {\n        if (oldState.status === AudioPlayerStatus.Idle || oldState.status === AudioPlayerStatus.Buffering) {\n          return this.emit('start', this.audioResource!);\n        }\n      } else if (newState.status === AudioPlayerStatus.Idle && oldState.status !== AudioPlayerStatus.Idle) {\n        this.emit('finish', this.audioResource!);\n        this.dsp.destroy();\n        this.audioResource = null;\n      }\n    });\n\n    this.voiceConnection.subscribe(this.audioPlayer);\n  }\n\n  /**\n   * Check if the player has been paused manually\n   */\n  get paused() {\n    return this.audioPlayer.state.status === AudioPlayerStatus.Paused;\n  }\n\n  set paused(val: boolean) {\n    val ? this.pause(true) : this.resume();\n  }\n\n  /**\n   * Whether or not the player is currently paused automatically or manually.\n   */\n  isPaused() {\n    return this.paused || this.audioPlayer.state.status === AudioPlayerStatus.AutoPaused;\n  }\n\n  /**\n   * Whether or not the player is currently buffering\n   */\n  isBuffering() {\n    return this.audioPlayer.state.status === AudioPlayerStatus.Buffering;\n  }\n\n  /**\n   * Whether or not the player is currently playing\n   */\n  isPlaying() {\n    return this.audioPlayer.state.status === AudioPlayerStatus.Playing;\n  }\n\n  /**\n   * Whether or not the player is currently idle\n   */\n  isIdle() {\n    return this.audioPlayer.state.status === AudioPlayerStatus.Idle;\n  }\n\n  /**\n   * Whether or not the voice connection has been destroyed\n   */\n  isDestroyed() {\n    return this.voiceConnection.state.status === VoiceConnectionStatus.Destroyed;\n  }\n\n  /**\n   * Whether or not the voice connection has been destroyed\n   */\n  isDisconnected() {\n    return this.voiceConnection.state.status === VoiceConnectionStatus.Disconnected;\n  }\n\n  /**\n   * Whether or not the voice connection is ready to play\n   */\n  isReady() {\n    return this.voiceConnection.state.status === VoiceConnectionStatus.Ready;\n  }\n\n  /**\n   * Whether or not the voice connection is signalling\n   */\n  isSignalling() {\n    return this.voiceConnection.state.status === VoiceConnectionStatus.Signalling;\n  }\n\n  /**\n   * Whether or not the voice connection is connecting\n   */\n  isConnecting() {\n    return this.voiceConnection.state.status === VoiceConnectionStatus.Connecting;\n  }\n\n  /**\n   * Creates stream\n   * @param {Readable} src The stream source\n   * @param {object} [ops] Options\n   * @returns {AudioResource}\n   */\n  async createStream(src: Readable, ops?: CreateStreamOps) {\n    if (!ops?.disableFilters && this.queue.hasDebugger) this.queue.debug('Initiating DSP filters pipeline...');\n    const stream = !ops?.disableFilters\n      ? this.dsp.create(src, {\n          dsp: {\n            filters: ops?.defaultFilters,\n            disabled: ops?.disableFilters,\n          },\n          biquad: ops?.biquadFilter\n            ? {\n                filter: ops.biquadFilter,\n                disabled: ops?.disableBiquad,\n              }\n            : undefined,\n          resampler: {\n            targetSampleRate: ops?.sampleRate,\n            disabled: ops?.disableResampler,\n          },\n          equalizer: {\n            bandMultiplier: ops?.eq,\n            disabled: ops?.disableEqualizer,\n          },\n          volume: {\n            volume: ops?.volume,\n            disabled: ops?.disableVolume,\n          },\n        })\n      : src;\n\n    if (this.queue.hasDebugger) this.queue.debug('Executing onAfterCreateStream hook...');\n    const postStream = await this.queue.onAfterCreateStream?.(stream, this.queue).catch(\n      () =>\n        ({\n          stream: stream,\n          type: ops?.type ?? StreamType.Arbitrary,\n        } as PostProcessedResult),\n    );\n\n    if (this.queue.hasDebugger) this.queue.debug('Preparing AudioResource...');\n    this.audioResource = createAudioResource(postStream?.stream ?? stream, {\n      inputType: postStream?.type ?? ops?.type ?? StreamType.Arbitrary,\n      metadata: ops?.data,\n      // volume controls happen from AudioFilter DSP utility\n      inlineVolume: false,\n    });\n\n    return this.audioResource;\n  }\n\n  public get resampler() {\n    return this.dsp?.resampler;\n  }\n\n  public get filters() {\n    return this.dsp?.filters;\n  }\n\n  public get biquad() {\n    return this.dsp?.biquad || null;\n  }\n\n  public get equalizer() {\n    return this.dsp?.equalizer || null;\n  }\n\n  /**\n   * The player status\n   * @type {AudioPlayerStatus}\n   */\n  get status() {\n    return this.audioPlayer.state.status;\n  }\n\n  /**\n   * Disconnects from voice\n   * @returns {void}\n   */\n  disconnect() {\n    try {\n      if (this.audioPlayer) this.audioPlayer.stop(true);\n      if (this.voiceConnection.state.status !== VoiceConnectionStatus.Destroyed) this.voiceConnection.destroy();\n    } catch {} // eslint-disable-line no-empty\n  }\n\n  /**\n   * Destroys this dispatcher\n   */\n  public destroy() {\n    this.disconnect();\n    // @ts-ignore\n    this.audioPlayer.removeAllListeners();\n    // @ts-ignore\n    this.voiceConnection.removeAllListeners();\n    this.dsp.destroy();\n    this.audioResource = null;\n    this.emit('destroyed');\n  }\n\n  /**\n   * Stops the player\n   * @returns {void}\n   */\n  end() {\n    try {\n      this.audioPlayer.stop();\n      this.dsp.destroy();\n    } catch {\n      //\n    }\n  }\n\n  /**\n   * Pauses the stream playback\n   * @param {boolean} [interpolateSilence=false] If true, the player will play 5 packets of silence after pausing to prevent audio glitches.\n   * @returns {boolean}\n   */\n  pause(interpolateSilence?: boolean) {\n    const success = this.audioPlayer.pause(interpolateSilence);\n    return success;\n  }\n\n  /**\n   * Resumes the stream playback\n   * @returns {boolean}\n   */\n  resume() {\n    const success = this.audioPlayer.unpause();\n    return success;\n  }\n\n  /**\n   * Play stream\n   * @param {AudioResource<Track>} [resource=this.audioResource] The audio resource to play\n   * @param {boolean} [opus=false] Whether or not to use opus\n   * @returns {Promise<StreamDispatcher>}\n   */\n  async playStream(resource: AudioResource<Track> = this.audioResource!) {\n    if (!resource) {\n      throw Exceptions.ERR_NO_AUDIO_RESOURCE();\n    }\n    if (resource.ended) {\n      return void this.emit('finish', resource);\n    }\n    if (!this.audioResource) this.audioResource = resource;\n    if (this.voiceConnection.state.status !== VoiceConnectionStatus.Ready) {\n      try {\n        await entersState(this.voiceConnection, VoiceConnectionStatus.Ready, this.connectionTimeout);\n      } catch (err) {\n        return void this.emit('error', err as AudioPlayerError);\n      }\n    }\n\n    try {\n      this.audioPlayer.play(resource);\n    } catch (e) {\n      this.emit('error', e as AudioPlayerError);\n    }\n\n    return this;\n  }\n\n  /**\n   * Sets playback volume\n   * @param {number} value The volume amount\n   * @returns {boolean}\n   */\n  setVolume(value: number) {\n    if (!this.dsp.volume) return false;\n    return this.dsp.volume.setVolume(value);\n  }\n\n  /**\n   * The current volume\n   * @type {number}\n   */\n  get volume() {\n    if (!this.dsp.volume) return 100;\n    return this.dsp.volume.volume;\n  }\n\n  /**\n   * The playback time\n   * @type {number}\n   */\n  get streamTime() {\n    if (!this.audioResource) return 0;\n    return this.audioResource.playbackDuration;\n  }\n}\n\nexport { StreamDispatcher as StreamDispatcher };\n", "import { Queue } from '@discord-player/utils';\nimport { Exceptions } from '../errors';\nimport { Track } from '../fabric/Track';\nimport { GuildQueue, TrackSkipReason } from './GuildQueue';\n\nexport class GuildQueueHistory<Meta = unknown> {\n  public tracks = new Queue<Track>('LIFO');\n  public constructor(public queue: GuildQueue<Meta>) {}\n\n  /**\n   * Current track in the queue\n   */\n  public get currentTrack() {\n    // eslint-disable-next-line @typescript-eslint/no-explicit-any\n    return this.queue.dispatcher?.audioResource?.metadata || ((this.queue as any).__current as Track | null);\n  }\n\n  /**\n   * Next track in the queue\n   */\n  public get nextTrack() {\n    return this.queue.tracks.at(0) || null;\n  }\n\n  /**\n   * Previous track in the queue\n   */\n  public get previousTrack() {\n    return this.tracks.at(0) || null;\n  }\n\n  /**\n   * If history is disabled\n   */\n  public get disabled() {\n    return this.queue.options.disableHistory;\n  }\n\n  /**\n   * Gets the size of the queue\n   */\n  public get size() {\n    return this.tracks.size;\n  }\n\n  public getSize() {\n    return this.size;\n  }\n\n  /**\n   * If history is empty\n   */\n  public isEmpty() {\n    return this.tracks.size < 1;\n  }\n\n  /**\n   * Add track to track history\n   * @param track The track to add\n   */\n  public push(track: Track | Track[]) {\n    if (this.disabled) return false;\n    this.tracks.add(track);\n\n    this.resize();\n\n    return true;\n  }\n\n  /**\n   * Clear history\n   */\n  public clear() {\n    this.tracks.clear();\n  }\n\n  /**\n   * Play the next track in the queue\n   */\n  public async next() {\n    const track = this.nextTrack;\n    if (!track) {\n      throw Exceptions.ERR_NO_RESULT('No next track in the queue');\n    }\n\n    this.queue.node.skip({\n      reason: TrackSkipReason.HistoryNext,\n      description: 'Skipped by GuildQueueHistory.next()',\n    });\n  }\n\n  /**\n   * Play the previous track in the queue\n   */\n  public async previous(preserveCurrent = true) {\n    const track = this.tracks.dispatch();\n    if (!track) {\n      throw Exceptions.ERR_NO_RESULT('No previous track in the queue');\n    }\n\n    const current = this.currentTrack;\n\n    await this.queue.node.play(track, { queue: false });\n    if (current && preserveCurrent) this.queue.node.insert(current, 0);\n  }\n\n  /**\n   * Alias to [GuildQueueHistory].previous()\n   */\n  public back(preserveCurrent = true) {\n    return this.previous(preserveCurrent);\n  }\n\n  /**\n   * Resize history store\n   */\n  public resize() {\n    if (!Number.isFinite(this.queue.maxHistorySize)) return;\n    if (this.tracks.store.length < this.queue.maxHistorySize) return;\n    this.tracks.store.splice(this.queue.maxHistorySize);\n  }\n}\n", "import { AudioResource, StreamType } from 'discord-voip';\nimport { Readable } from 'stream';\nimport { PlayerProgressbarOptions, SearchQueryType } from '../types/types';\nimport { QueryResolver } from '../utils/QueryResolver';\nimport { Util, VALIDATE_QUEUE_CAP } from '../utils/Util';\nimport { Track, TrackResolvable } from '../fabric/Track';\nimport { GuildQueue, GuildQueueEvent, TrackSkipReason } from './GuildQueue';\nimport { setTimeout as waitFor } from 'timers/promises';\nimport { AsyncQueue } from '../utils/AsyncQueue';\nimport { Exceptions } from '../errors';\nimport { TypeUtil } from '../utils/TypeUtil';\nimport { CreateStreamOps } from '../VoiceInterface/StreamDispatcher';\nimport { ExtractorStreamable } from '../extractors/BaseExtractor';\nimport { OggDemuxer, OpusDecoder, WebmDemuxer } from '@discord-player/opus';\n\nexport const FFMPEG_SRATE_REGEX = /asetrate=\\d+\\*(\\d(\\.\\d)?)/;\n\nexport interface ResourcePlayOptions {\n  queue?: boolean;\n  seek?: number;\n  transitionMode?: boolean;\n}\n\nexport interface SkipOptions {\n  reason: TrackSkipReason;\n  description: string;\n}\n\nexport interface PlayerTimestamp {\n  current: {\n    label: string;\n    value: number;\n  };\n  total: {\n    label: string;\n    value: number;\n  };\n  progress: number;\n}\n\nexport interface StreamConfig {\n  dispatcherConfig: CreateStreamOps;\n  playerConfig: ResourcePlayOptions;\n}\n\nexport class GuildQueuePlayerNode<Meta = unknown> {\n  #progress = 0;\n  #hasFFmpegOptimization = false;\n  public tasksQueue = new AsyncQueue();\n  public constructor(public queue: GuildQueue<Meta>) {\n    this.#hasFFmpegOptimization = /libopus: (yes|true)/.test(this.queue.player.scanDeps());\n  }\n\n  /**\n   * If the player is currently in idle mode\n   */\n  public isIdle() {\n    return !!this.queue.dispatcher?.isIdle();\n  }\n\n  /**\n   * If the player is currently buffering the track\n   */\n  public isBuffering() {\n    return !!this.queue.dispatcher?.isBuffering();\n  }\n\n  /**\n   * If the player is currently playing a track\n   */\n  public isPlaying() {\n    return !!this.queue.dispatcher?.isPlaying();\n  }\n\n  /**\n   * If the player is currently paused\n   */\n  public isPaused() {\n    return !!this.queue.dispatcher?.isPaused();\n  }\n\n  /**\n   * Reset progress history\n   */\n  public resetProgress() {\n    this.#progress = 0;\n  }\n\n  /**\n   * Set player progress\n   */\n  public setProgress(progress: number) {\n    this.#progress = progress;\n  }\n\n  /**\n   * The stream time for current session\n   */\n  public get streamTime() {\n    return this.queue.dispatcher?.streamTime ?? 0;\n  }\n\n  /**\n   * Current playback duration with history included\n   */\n  public get playbackTime() {\n    const dur = this.#progress + this.streamTime;\n\n    return dur;\n  }\n\n  /**\n   * Get duration multiplier\n   */\n  public getDurationMultiplier() {\n    const srateFilters = this.queue.filters.ffmpeg.toArray().filter((ff) => FFMPEG_SRATE_REGEX.test(ff));\n    const multipliers = srateFilters\n      .map((m) => {\n        return parseFloat(FFMPEG_SRATE_REGEX.exec(m)?.[1] as string);\n      })\n      .filter((f) => !isNaN(f));\n\n    return !multipliers.length ? 1 : multipliers.reduce((accumulator, current) => current + accumulator);\n  }\n\n  /**\n   * Estimated progress of the player\n   */\n  public get estimatedPlaybackTime() {\n    const dur = this.playbackTime;\n    return Math.round(this.getDurationMultiplier() * dur);\n  }\n\n  /**\n   * Estimated total duration of the player\n   */\n  public get estimatedDuration() {\n    const dur = this.totalDuration;\n\n    return Math.round(dur / this.getDurationMultiplier());\n  }\n\n  /**\n   * Total duration of the current audio track\n   */\n  public get totalDuration() {\n    const prefersBridgedMetadata = this.queue.options.preferBridgedMetadata;\n    const track = this.queue.currentTrack;\n\n    if (prefersBridgedMetadata) {\n      const trackHasLegacyMetadata =\n        track?.metadata != null &&\n        typeof track.metadata === 'object' &&\n        'bridge' in track.metadata &&\n        track.metadata.bridge != null;\n      const trackHasMetadata = track?.bridgedTrack != null;\n\n      if (trackHasLegacyMetadata || trackHasMetadata) {\n        const duration =\n          track.bridgedTrack?.durationMS ??\n          (\n            track as Track<{\n              bridge: {\n                duration: number;\n              };\n            }>\n          ).metadata?.bridge.duration;\n\n        if (TypeUtil.isNumber(duration)) return duration;\n      }\n    }\n\n    return track?.durationMS ?? 0;\n  }\n\n  /**\n   * Get stream progress\n   * @param ignoreFilters Ignore filters\n   */\n  public getTimestamp(ignoreFilters = false): PlayerTimestamp | null {\n    if (!this.queue.currentTrack) return null;\n\n    const current = ignoreFilters ? this.playbackTime : this.estimatedPlaybackTime;\n    const total = ignoreFilters ? this.totalDuration : this.estimatedDuration;\n\n    return {\n      current: {\n        label: Util.buildTimeCode(Util.parseMS(current)),\n        value: current,\n      },\n      total: {\n        label: Util.buildTimeCode(Util.parseMS(total)),\n        value: total,\n      },\n      progress: Math.round((current / total) * 100),\n    };\n  }\n\n  /**\n   * Create progress bar for current progress\n   * @param options Progress bar options\n   */\n  public createProgressBar(options?: PlayerProgressbarOptions) {\n    const timestamp = this.getTimestamp();\n    if (!timestamp) return null;\n    const {\n      indicator = '\\u{1F518}',\n      leftChar = '\\u25AC',\n      rightChar = '\\u25AC',\n      length = 15,\n      timecodes = true,\n      separator = '\\u2503',\n    } = options || {};\n    if (isNaN(length) || length < 0 || !Number.isFinite(length)) {\n      throw Exceptions.ERR_OUT_OF_RANGE('[PlayerProgressBarOptions.length]', String(length), '0', 'Finite Number');\n    }\n    const index = Math.round((timestamp.current.value / timestamp.total.value) * length);\n    if (index >= 1 && index <= length) {\n      const bar = leftChar.repeat(index - 1).split('');\n      bar.push(indicator);\n      bar.push(rightChar.repeat(length - index));\n      if (timecodes) {\n        return `${timestamp.current.label} ${separator} ${bar.join('')} ${separator} ${timestamp.total.label}`;\n      } else {\n        return `${bar.join('')}`;\n      }\n    } else {\n      if (timecodes) {\n        return `${timestamp.current.label} ${separator} ${indicator}${rightChar.repeat(length - 1)} ${separator} ${\n          timestamp.total.label\n        }`;\n      } else {\n        return `${indicator}${rightChar.repeat(length - 1)}`;\n      }\n    }\n  }\n\n  /**\n   * Seek the player\n   * @param duration The duration to seek to\n   */\n  public async seek(duration: number) {\n    if (!this.queue.currentTrack) return false;\n    if (duration === this.estimatedPlaybackTime) return true;\n    if (duration > this.totalDuration) {\n      return this.skip({\n        reason: TrackSkipReason.SEEK_OVER_THRESHOLD,\n        description: Exceptions.ERR_OUT_OF_RANGE('[duration]', String(duration), '0', String(this.totalDuration))\n          .message,\n      });\n    }\n    if (duration < 0) duration = 0;\n    return await this.queue.filters.triggerReplay(duration);\n  }\n\n  /**\n   * Current volume\n   */\n  public get volume() {\n    return this.queue.dispatcher?.volume ?? 100;\n  }\n\n  /**\n   * Set volume\n   * @param vol Volume amount to set\n   */\n  public setVolume(vol: number) {\n    if (!this.queue.dispatcher) return false;\n    const res = this.queue.dispatcher.setVolume(vol);\n    if (res) this.queue.filters._lastFiltersCache.volume = vol;\n    return res;\n  }\n\n  /**\n   * Set bit rate\n   * @param rate The bit rate to set\n   */\n  public setBitrate(rate: number | 'auto') {\n    this.queue.dispatcher?.audioResource?.encoder?.setBitrate(\n      rate === 'auto' ? this.queue.channel?.bitrate ?? 64000 : rate,\n    );\n  }\n\n  /**\n   * Set paused state\n   * @param state The state\n   */\n  public setPaused(state: boolean) {\n    if (state) return this.queue.dispatcher?.pause(true) || false;\n    return this.queue.dispatcher?.resume() || false;\n  }\n\n  /**\n   * Pause the playback\n   */\n  public pause() {\n    return this.setPaused(true);\n  }\n\n  /**\n   * Resume the playback\n   */\n  public resume() {\n    return this.setPaused(false);\n  }\n\n  /**\n   * Skip current track\n   */\n  public skip(options?: SkipOptions) {\n    if (!this.queue.dispatcher) return false;\n    const track = this.queue.currentTrack;\n    if (!track) return false;\n    this.queue.setTransitioning(false);\n    this.queue.dispatcher.end();\n    const { reason, description } = options || {\n      reason: TrackSkipReason.Manual,\n      description: 'The track was skipped manually',\n    };\n    this.queue.emit(GuildQueueEvent.PlayerSkip, this.queue, track, reason, description);\n    return true;\n  }\n\n  /**\n   * Remove the given track from queue\n   * @param track The track to remove\n   * @param emitEvent Whether or not to emit the event @defaultValue true\n   */\n  public remove(track: TrackResolvable, emitEvent = true) {\n    const foundTrack = this.queue.tracks.find((t, idx) => {\n      if (track instanceof Track || typeof track === 'string') {\n        return (typeof track === 'string' ? track : track.id) === t.id;\n      }\n      if (typeof track === 'string') return track === t.id;\n      return idx === track;\n    });\n    if (!foundTrack) return null;\n\n    this.queue.tracks.removeOne((t) => t.id === foundTrack.id);\n\n    if (emitEvent) this.queue.emit(GuildQueueEvent.AudioTrackRemove, this.queue, foundTrack);\n\n    return foundTrack;\n  }\n\n  /**\n   * Jump to specific track on the queue\n   * @param track The track to jump to without removing other tracks\n   */\n  public jump(track: TrackResolvable) {\n    const removed = this.remove(track, false);\n    if (!removed) return false;\n    this.queue.tracks.store.unshift(removed);\n    return this.skip({\n      reason: TrackSkipReason.Jump,\n      description: 'The track was jumped to manually',\n    });\n  }\n\n  /**\n   * Get track position\n   * @param track The track\n   */\n  public getTrackPosition(track: TrackResolvable): number {\n    return this.queue.tracks.toArray().findIndex((t, idx) => {\n      if (track instanceof Track || typeof track === 'string') {\n        return (typeof track === 'string' ? track : track.id) === t.id;\n      }\n      if (typeof track === 'string') return track === t.id;\n      return idx === track;\n    });\n  }\n\n  /**\n   * Skip to the given track, removing others on the way\n   * @param track The track to skip to\n   */\n  public skipTo(track: TrackResolvable) {\n    const idx = this.getTrackPosition(track);\n    if (idx < 0) return false;\n    const removed = this.remove(idx);\n    if (!removed) return false;\n    const toRemove = this.queue.tracks.store.filter((_, i) => i <= idx);\n    this.queue.tracks.store.splice(0, idx, removed);\n    this.queue.emit(GuildQueueEvent.AudioTracksRemove, this.queue, toRemove);\n    return this.skip({\n      reason: TrackSkipReason.SkipTo,\n      description: 'The player was skipped to another track manually',\n    });\n  }\n\n  /**\n   * Insert a track on the given position in queue\n   * @param track The track to insert\n   * @param index The position to insert to, defaults to 0.\n   */\n  public insert(track: Track, index = 0) {\n    if (!(track instanceof Track))\n      throw Exceptions.ERR_INVALID_ARG_TYPE('track value', 'instance of Track', String(track));\n    VALIDATE_QUEUE_CAP(this.queue, track);\n    this.queue.tracks.store.splice(index, 0, track);\n    if (!this.queue.options.noEmitInsert) this.queue.emit(GuildQueueEvent.AudioTrackAdd, this.queue, track);\n  }\n\n  /**\n   * Moves a track in the queue\n   * @param from The track to move\n   * @param to The position to move to\n   */\n  public move(from: TrackResolvable, to: number) {\n    const removed = this.remove(from);\n    if (!removed) {\n      throw Exceptions.ERR_NO_RESULT('invalid track to move');\n    }\n    this.insert(removed, to);\n  }\n\n  /**\n   * Copy a track in the queue\n   * @param from The track to clone\n   * @param to The position to clone at\n   */\n  public copy(from: TrackResolvable, to: number) {\n    const src = this.queue.tracks.at(this.getTrackPosition(from));\n    if (!src) {\n      throw Exceptions.ERR_NO_RESULT('invalid track to copy');\n    }\n    this.insert(src, to);\n  }\n\n  /**\n   * Swap two tracks in the queue\n   * @param first The first track to swap\n   * @param second The second track to swap\n   */\n  public swap(first: TrackResolvable, second: TrackResolvable) {\n    const src = this.getTrackPosition(first);\n    if (src < 0) throw Exceptions.ERR_NO_RESULT('invalid src track to swap');\n\n    const dest = this.getTrackPosition(second);\n    if (dest < 0) throw Exceptions.ERR_NO_RESULT('invalid dest track to swap');\n\n    const srcT = this.queue.tracks.store[src];\n    const destT = this.queue.tracks.store[dest];\n\n    this.queue.tracks.store[src] = destT;\n    this.queue.tracks.store[dest] = srcT;\n  }\n\n  /**\n   * Stop the playback\n   * @param force Whether or not to forcefully stop the playback\n   */\n  public stop(force = false) {\n    this.queue.tracks.clear();\n    this.queue.history.clear();\n    if (!this.queue.dispatcher) return false;\n    this.queue.dispatcher.end();\n    if (force) {\n      this.queue.dispatcher.destroy();\n      return true;\n    }\n    if (this.queue.options.leaveOnStop) {\n      const tm: NodeJS.Timeout = setTimeout(() => {\n        if (this.isPlaying() || this.queue.tracks.size) return clearTimeout(tm);\n        this.queue.dispatcher?.destroy();\n      }, this.queue.options.leaveOnStopCooldown).unref();\n    }\n    return true;\n  }\n\n  /**\n   * Play raw audio resource\n   * @param resource The audio resource to play\n   */\n  public async playRaw(resource: AudioResource) {\n    await this.queue.dispatcher?.playStream(resource as AudioResource<Track>);\n  }\n\n  /**\n   * Play the given track\n   * @param res The track to play\n   * @param options Options for playing the track\n   */\n  public async play(res?: Track | null, options?: ResourcePlayOptions) {\n    if (!this.queue.dispatcher?.voiceConnection) {\n      throw Exceptions.ERR_NO_VOICE_CONNECTION();\n    }\n\n    if (this.queue.hasDebugger)\n      this.queue.debug(`Received play request from guild ${this.queue.guild.name} (ID: ${this.queue.guild.id})`);\n\n    options = Object.assign(\n      {},\n      {\n        queue: this.queue.currentTrack != null,\n        transitionMode: false,\n        seek: 0,\n      } as ResourcePlayOptions,\n      options,\n    )!;\n\n    if (res && options.queue) {\n      if (this.queue.hasDebugger)\n        this.queue.debug('Requested option requires to queue the track, adding the given track to queue instead...');\n      return this.queue.addTrack(res);\n    }\n\n    const track = res || this.queue.tracks.dispatch();\n    if (!track) {\n      const error = Exceptions.ERR_NO_RESULT('Play request received but track was not provided');\n      this.queue.emit(GuildQueueEvent.Error, this.queue, error);\n      return;\n    }\n\n    if (this.queue.hasDebugger) this.queue.debug('Requested option requires to play the track, initializing...');\n\n    try {\n      if (this.queue.hasDebugger) this.queue.debug(`Initiating stream extraction process...`);\n      const src = track.raw?.source || track.source;\n      const qt: SearchQueryType =\n        track.queryType || (src === 'spotify' ? 'spotifySong' : src === 'apple_music' ? 'appleMusicSong' : src);\n      if (this.queue.hasDebugger) this.queue.debug(`Executing onBeforeCreateStream hook (QueryType: ${qt})...`);\n\n      const streamSrc = {\n        error: null as Error | null,\n        stream: null as ExtractorStreamable | null,\n      };\n\n      await this.queue.onBeforeCreateStream?.(track, qt || 'arbitrary', this.queue).then(\n        (s) => {\n          if (s) {\n            streamSrc.stream = s;\n          }\n        },\n        (e: Error) => (streamSrc.error = e),\n      );\n\n      // throw if 'onBeforeCreateStream' panics\n      if (!streamSrc.stream && streamSrc.error) return this.#throw(track, streamSrc.error);\n\n      // default behavior when 'onBeforeCreateStream' did not panic\n      if (!streamSrc.stream) {\n        if (this.queue.hasDebugger) this.queue.debug('Failed to get stream from onBeforeCreateStream!');\n        await this.queue.player.extractors.context.provide(\n          {\n            id: crypto.randomUUID(),\n            attemptedExtractors: new Set<string>(),\n            bridgeAttemptedExtractors: new Set<string>(),\n          },\n          () =>\n            this.#createGenericStream(track).then(\n              (r) => {\n                if (r?.result) {\n                  streamSrc.stream = <Readable>r.result;\n                  return;\n                }\n\n                if (r?.error) {\n                  streamSrc.error = r.error;\n                  return;\n                }\n\n                streamSrc.stream = streamSrc.error = null;\n              },\n              (e: Error) => (streamSrc.error = e),\n            ),\n        );\n      }\n\n      if (!streamSrc.stream) return this.#throw(track, streamSrc.error);\n\n      if (typeof options.seek === 'number' && options.seek >= 0) {\n        this.#progress = options.seek;\n      } else {\n        this.#progress = 0;\n      }\n\n      const trackStreamConfig: StreamConfig = {\n        dispatcherConfig: {\n          disableBiquad: this.queue.options.disableBiquad,\n          disableEqualizer: this.queue.options.disableEqualizer,\n          disableVolume: this.queue.options.disableVolume,\n          disableFilters: this.queue.options.disableFilterer,\n          disableResampler: this.queue.options.disableResampler,\n          sampleRate:\n            typeof this.queue.options.resampler === 'number' && this.queue.options.resampler > 0\n              ? this.queue.options.resampler\n              : undefined,\n          biquadFilter: this.queue.filters._lastFiltersCache.biquad || undefined,\n          eq: this.queue.filters._lastFiltersCache.equalizer,\n          defaultFilters: this.queue.filters._lastFiltersCache.filters,\n          volume: this.queue.filters._lastFiltersCache.volume,\n          data: track,\n          type: StreamType.Raw,\n          skipFFmpeg: this.queue.player.options.skipFFmpeg,\n        },\n        playerConfig: options,\n      };\n\n      let resolver: () => void = Util.noop;\n      const donePromise = new Promise<void>((resolve) => (resolver = resolve));\n\n      const success = this.queue.emit(GuildQueueEvent.WillPlayTrack, this.queue, track, trackStreamConfig, resolver!);\n\n      // prevent dangling promise\n      if (!success) resolver();\n\n      if (this.queue.hasDebugger) this.queue.debug('Waiting for willPlayTrack event to resolve...');\n\n      await donePromise;\n\n      // prettier-ignore\n      const daspDisabled = [\n                trackStreamConfig.dispatcherConfig.disableBiquad,\n                trackStreamConfig.dispatcherConfig.disableEqualizer,\n                trackStreamConfig.dispatcherConfig.disableFilters,\n                trackStreamConfig.dispatcherConfig.disableResampler,\n                trackStreamConfig.dispatcherConfig.disableVolume\n            ].every((e) => !!e === true);\n\n      const needsFilters = !!trackStreamConfig.playerConfig.seek || !!this.queue.filters.ffmpeg.args.length;\n      const shouldSkipFFmpeg = !!trackStreamConfig.dispatcherConfig.skipFFmpeg && !needsFilters;\n\n      let finalStream: Readable;\n\n      const demuxable = (fmt: string) =>\n        [StreamType.Opus, StreamType.WebmOpus, StreamType.OggOpus].includes(fmt as StreamType);\n\n      // skip ffmpeg when possible\n      if (\n        shouldSkipFFmpeg &&\n        !(streamSrc.stream instanceof Readable) &&\n        typeof streamSrc.stream !== 'string' &&\n        demuxable(streamSrc.stream.$fmt)\n      ) {\n        const { $fmt, stream } = streamSrc.stream;\n        const shouldPCM = !daspDisabled;\n\n        if (this.queue.hasDebugger)\n          this.queue.debug(\n            `skipFFmpeg is set to true and stream is demuxable, creating stream with type ${\n              shouldPCM ? 'pcm' : 'opus'\n            }`,\n          );\n\n        // prettier-ignore\n        const opusStream = $fmt === StreamType.Opus ?\n                    stream :\n                    $fmt === StreamType.OggOpus ?\n                    // eslint-disable-next-line @typescript-eslint/no-explicit-any\n                    stream.pipe(new OggDemuxer() as any) :\n                    // eslint-disable-next-line @typescript-eslint/no-explicit-any\n                    stream.pipe(new WebmDemuxer() as any);\n\n        if (shouldPCM) {\n          // if we have any filters enabled, we need to decode the opus stream to pcm\n          finalStream = opusStream.pipe(\n            new OpusDecoder({\n              channels: 2,\n              frameSize: 960,\n              rate: 48000,\n            }),\n          );\n          trackStreamConfig.dispatcherConfig.type = StreamType.Raw;\n        } else {\n          finalStream = opusStream;\n          trackStreamConfig.dispatcherConfig.type = StreamType.Opus;\n        }\n      } else {\n        // const opus = daspDisabled && this.#hasFFmpegOptimization;\n        // if (opus && this.queue.hasDebugger) this.queue.debug('Disabling PCM output since all filters are disabled and opus encoding is supported...');\n\n        finalStream = this.#createFFmpegStream(\n          streamSrc.stream instanceof Readable || typeof streamSrc.stream === 'string'\n            ? streamSrc.stream\n            : streamSrc.stream.stream,\n          track,\n          options.seek ?? 0,\n          // opus\n        );\n        trackStreamConfig.dispatcherConfig.type = StreamType.Raw;\n        // FIXME: OggOpus results in static noise\n        // trackStreamConfig.dispatcherConfig.type = opus ? StreamType.OggOpus : StreamType.Raw;\n      }\n\n      if (options.transitionMode) {\n        if (this.queue.hasDebugger)\n          this.queue.debug(\n            `Transition mode detected, player will wait for buffering timeout to expire (Timeout: ${this.queue.options.bufferingTimeout}ms)`,\n          );\n        await waitFor(this.queue.options.bufferingTimeout);\n        if (this.queue.hasDebugger) this.queue.debug('Buffering timeout has expired!');\n      }\n\n      if (this.queue.hasDebugger)\n        this.queue.debug(`Preparing final stream config: ${JSON.stringify(trackStreamConfig, null, 2)}`);\n\n      const dispatcher = this.queue.dispatcher;\n\n      if (!dispatcher) {\n        if (this.queue.hasDebugger) {\n          this.queue.debug(\n            'Dispatcher is not available, this is most likely due to the queue being deleted in the middle of operation. Cancelling the stream...',\n          );\n        }\n\n        finalStream.destroy();\n      } else {\n        const resource = await dispatcher.createStream(finalStream, trackStreamConfig.dispatcherConfig);\n\n        this.queue.setTransitioning(!!options.transitionMode);\n\n        await this.#performPlay(resource);\n      }\n    } catch (e) {\n      if (this.queue.hasDebugger) this.queue.debug(`Failed to initialize audio player: ${e}`);\n      throw e;\n    }\n  }\n\n  #throw(track: Track, error?: Error | null): void {\n    // prettier-ignore\n    const streamDefinitelyFailedMyDearT_TPleaseTrustMeItsNotMyFault = (\n            Exceptions.ERR_NO_RESULT(`Could not extract stream for this track${error ? `\\n\\n${error.stack || error}` : ''}`)\n        );\n\n    this.queue.emit(\n      GuildQueueEvent.PlayerSkip,\n      this.queue,\n      track,\n      TrackSkipReason.NoStream,\n      streamDefinitelyFailedMyDearT_TPleaseTrustMeItsNotMyFault.message,\n    );\n    this.queue.emit(\n      GuildQueueEvent.PlayerError,\n      this.queue,\n      streamDefinitelyFailedMyDearT_TPleaseTrustMeItsNotMyFault,\n      track,\n    );\n    const nextTrack = this.queue.tracks.dispatch();\n    if (nextTrack) return void this.play(nextTrack, { queue: false });\n    // @ts-expect-error should be resolved\n    this.queue.dispatcher?.emit('finish', null);\n  }\n\n  async #performPlay(resource: AudioResource<Track>) {\n    if (!this.queue.dispatcher) {\n      if (this.queue.hasDebugger) {\n        this.queue.debug(\n          'Dispatcher is not available, this is most likely due to the queue being deleted in the middle of operation. Cancelling the stream...',\n        );\n      }\n    } else {\n      if (this.queue.hasDebugger) this.queue.debug('Initializing audio player...');\n      await this.queue.dispatcher.playStream(resource);\n      if (this.queue.hasDebugger) this.queue.debug('Dispatching audio...');\n    }\n  }\n\n  async #createGenericStream(track: Track) {\n    if (this.queue.hasDebugger)\n      this.queue.debug(\n        `Attempting to extract stream for Track { title: ${track.title}, url: ${track.url} } using registered extractors`,\n      );\n\n    const attemptedExtractors = this.queue.player.extractors.getContext()?.attemptedExtractors || new Set<string>();\n\n    const streamInfo = await this.queue.player.extractors.run(async (extractor) => {\n      if (this.queue.player.options.blockStreamFrom?.some((ext) => ext === extractor.identifier)) return false;\n      if (attemptedExtractors.has(extractor.identifier)) return false;\n      attemptedExtractors.add(extractor.identifier);\n      const canStream = await extractor.validate(track.url, track.queryType || QueryResolver.resolve(track.url).type);\n      if (!canStream) return false;\n      return await extractor.stream(track);\n    }, false);\n\n    if (!streamInfo || !streamInfo.result) {\n      if (this.queue.hasDebugger) {\n        this.queue.debug(\n          `Failed to extract stream for Track { title: ${track.title}, url: ${track.url} } using registered extractors`,\n        );\n      }\n\n      if (!this.queue.options.disableFallbackStream) {\n        if (this.queue.hasDebugger)\n          this.queue.debug(`Generic stream extraction failed and fallback stream extraction is enabled`);\n        return this.#createFallbackStream(track);\n      }\n\n      return streamInfo || null;\n    }\n\n    if (this.queue.hasDebugger)\n      this.queue.debug(\n        `Stream extraction was successful for Track { title: ${track.title}, url: ${track.url} } (Extractor: ${\n          streamInfo.extractor?.identifier || 'N/A'\n        })`,\n      );\n\n    return streamInfo;\n  }\n\n  async #createFallbackStream(track: Track) {\n    if (this.queue.hasDebugger)\n      this.queue.debug(\n        `Attempting to extract stream for Track { title: ${track.title}, url: ${track.url} } using fallback streaming method...`,\n      );\n\n    const fallbackStream = await this.queue.player.extractors.run(async (extractor) => {\n      if (extractor.identifier === track.extractor?.identifier) return false;\n      if (this.queue.player.options.blockStreamFrom?.some((ext) => ext === extractor.identifier)) return false;\n\n      const query = `${track.title} ${track.author}`;\n      const fallbackTracks = await extractor.handle(query, {\n        requestedBy: track.requestedBy,\n      });\n\n      const fallbackTrack = fallbackTracks.tracks[0];\n\n      if (!fallbackTrack) return false;\n\n      const stream = await extractor.stream(fallbackTrack);\n\n      if (!stream) return false;\n\n      track.bridgedTrack = fallbackTrack;\n\n      return stream;\n    }, true);\n\n    if (!fallbackStream || !fallbackStream.result) {\n      if (this.queue.hasDebugger)\n        this.queue.debug(\n          `Failed to extract stream for Track { title: ${track.title}, url: ${track.url} } using fallback streaming method`,\n        );\n      return fallbackStream || null;\n    }\n\n    track.bridgedExtractor = fallbackStream.extractor;\n\n    return fallbackStream;\n  }\n\n  #createFFmpegStream(stream: Readable | string, track: Track, seek = 0, opus?: boolean) {\n    const ffmpegStream = this.queue.filters.ffmpeg\n      .createStream(stream, {\n        encoderArgs: this.queue.filters.ffmpeg.args,\n        seek: seek / 1000,\n        fmt: opus ? 'opus' : 's16le',\n        useLegacyFFmpeg: !!this.queue.player.options.useLegacyFFmpeg,\n      })\n      .on('error', (err) => {\n        const m = `${err}`.toLowerCase();\n\n        if (this.queue.hasDebugger)\n          this.queue.debug(`Stream closed due to an error from FFmpeg stream: ${err.stack || err.message || err}`);\n\n        if (m.includes('premature close') || m.includes('epipe')) return;\n\n        this.queue.emit(GuildQueueEvent.PlayerError, this.queue, err, track);\n      });\n\n    return ffmpegStream;\n  }\n}\n", "import { QueryType } from '../types/types';\nimport { TypeUtil } from './TypeUtil';\nimport { Exceptions } from '../errors';\nimport { fetch } from 'undici';\n\n// #region scary things below *sigh*\nconst spotifySongRegex =\n  /^https?:\\/\\/(?:embed\\.|open\\.)(?:spotify\\.com\\/)(intl-([a-z]|[A-Z])+\\/)?(?:track\\/|\\?uri=spotify:track:)((\\w|-){22})(\\?si=.+)?$/;\nconst spotifyPlaylistRegex =\n  /^https?:\\/\\/(?:embed\\.|open\\.)(?:spotify\\.com\\/)(intl-([a-z]|[A-Z])+\\/)?(?:playlist\\/|\\?uri=spotify:playlist:)((\\w|-){22})(\\?si=.+)?$/;\nconst spotifyAlbumRegex =\n  /^https?:\\/\\/(?:embed\\.|open\\.)(?:spotify\\.com\\/)(intl-([a-z]|[A-Z])+\\/)?(?:album\\/|\\?uri=spotify:album:)((\\w|-){22})(\\?si=.+)?$/;\nconst vimeoRegex =\n  /^(http|https)?:\\/\\/(www\\.|player\\.)?vimeo\\.com\\/(?:channels\\/(?:\\w+\\/)?|groups\\/([^/]*)\\/videos\\/|video\\/|)(\\d+)(?:|\\/\\?)$/;\nconst reverbnationRegex = /^https:\\/\\/(www.)?reverbnation.com\\/(.+)\\/song\\/(.+)$/;\nconst attachmentRegex = /^https?:\\/\\/.+$/;\nconst appleMusicSongRegex = /^https?:\\/\\/music\\.apple\\.com\\/.+?\\/(song|album)\\/.+?(\\/.+?\\?i=|\\/)([0-9]+)$/;\nconst appleMusicPlaylistRegex = /^https?:\\/\\/music\\.apple\\.com\\/.+?\\/playlist\\/.+\\/pl\\.(u-|pm-)?[a-zA-Z0-9]+$/;\nconst appleMusicAlbumRegex = /^https?:\\/\\/music\\.apple\\.com\\/.+?\\/album\\/.+\\/([0-9]+)$/;\nconst soundcloudTrackRegex = /^https?:\\/\\/(m.|www.)?soundcloud.com\\/(\\w|-)+\\/(\\w|-)+(.+)?$/;\nconst soundcloudPlaylistRegex = /^https?:\\/\\/(m.|www.)?soundcloud.com\\/(\\w|-)+\\/sets\\/(\\w|-)+(.+)?$/;\nconst youtubePlaylistRegex =\n  /^https?:\\/\\/(www.)?youtube.com\\/playlist\\?list=((PL|FL|UU|LL|RD|OL)[a-zA-Z0-9-_]{16,41})$/;\nconst youtubeVideoURLRegex =\n  /^((?:https?:)?\\/\\/)?((?:www|m)\\.)?((?:youtube\\.com|youtu.be))(\\/(?:[\\w-]+\\?v=|embed\\/|v\\/)?)([\\w-]+)(\\S+)?$/;\nconst youtubeVideoIdRegex = /^[a-zA-Z0-9-_]{11}$/;\n// #endregion scary things above *sigh*\n\nconst DomainsMap = {\n  YouTube: ['youtube.com', 'youtu.be', 'music.youtube.com', 'gaming.youtube.com', 'www.youtube.com', 'm.youtube.com'],\n  Spotify: ['open.spotify.com', 'embed.spotify.com'],\n  Vimeo: ['vimeo.com', 'player.vimeo.com'],\n  ReverbNation: ['reverbnation.com'],\n  SoundCloud: ['soundcloud.com'],\n  AppleMusic: ['music.apple.com'],\n};\n\n// prettier-ignore\nconst redirectDomains = new Set([\n    /^https?:\\/\\/spotify.link\\/[A-Za-z0-9]+$/,\n    /^https:\\/\\/on\\.soundcloud\\.com\\/[a-zA-Z1-9]{0,17}$/\n]);\n\nexport interface ResolvedQuery {\n  type: (typeof QueryType)[keyof typeof QueryType];\n  query: string;\n}\n\nclass QueryResolver {\n  /**\n   * Query resolver\n   */\n  private constructor() {} // eslint-disable-line @typescript-eslint/no-empty-function\n\n  static get regex() {\n    return {\n      spotifyAlbumRegex,\n      spotifyPlaylistRegex,\n      spotifySongRegex,\n      vimeoRegex,\n      reverbnationRegex,\n      attachmentRegex,\n      appleMusicAlbumRegex,\n      appleMusicPlaylistRegex,\n      appleMusicSongRegex,\n      soundcloudTrackRegex,\n      soundcloudPlaylistRegex,\n      youtubePlaylistRegex,\n    };\n  }\n\n  /**\n   * Pre-resolve redirect urls\n   */\n  static async preResolve(query: string, maxDepth = 5): Promise<string> {\n    if (!TypeUtil.isString(query)) throw Exceptions.ERR_INVALID_ARG_TYPE(query, 'string', typeof query);\n\n    for (const domain of redirectDomains) {\n      if (domain.test(query)) {\n        try {\n          const res = await fetch(query, {\n            method: 'GET',\n            redirect: 'follow',\n          });\n\n          if (!res.ok) break;\n\n          // spotify does not \"redirect\", it returns a page with js that redirects\n          if (/^https?:\\/\\/spotify.app.link\\/(.+)$/.test(res.url)) {\n            const body = await res.text();\n            const target = body.split('https://open.spotify.com/track/')[1].split('?si=')[0];\n\n            if (!target) break;\n\n            return `https://open.spotify.com/track/${target}`;\n          }\n          return maxDepth < 1 ? res.url : this.preResolve(res.url, maxDepth - 1);\n        } catch {\n          break;\n        }\n      }\n    }\n\n    return query;\n  }\n\n  /**\n   * Resolves the given search query\n   * @param {string} query The query\n   */\n  static resolve(\n    query: string,\n    fallbackSearchEngine: (typeof QueryType)[keyof typeof QueryType] = QueryType.AUTO_SEARCH,\n  ): ResolvedQuery {\n    if (!TypeUtil.isString(query)) throw Exceptions.ERR_INVALID_ARG_TYPE(query, 'string', typeof query);\n    if (!query.length) throw Exceptions.ERR_INFO_REQUIRED('query', String(query));\n\n    const resolver = (type: typeof fallbackSearchEngine, query: string) => ({ type, query });\n\n    try {\n      const url = new URL(query);\n\n      if (DomainsMap.YouTube.includes(url.host)) {\n        query = query.replace(/(m(usic)?|gaming)\\./, '').trim();\n        const playlistId = url.searchParams.get('list');\n        const videoId = url.searchParams.get('v');\n        if (playlistId) {\n          if (videoId && playlistId.startsWith('RD'))\n            return resolver(\n              QueryType.YOUTUBE_PLAYLIST,\n              `https://www.youtube.com/watch?v=${videoId}&list=${playlistId}`,\n            );\n          return resolver(QueryType.YOUTUBE_PLAYLIST, `https://www.youtube.com/playlist?list=${playlistId}`);\n        }\n        if (QueryResolver.validateId(query) || QueryResolver.validateURL(query))\n          return resolver(QueryType.YOUTUBE_VIDEO, query);\n        return resolver(fallbackSearchEngine, query);\n      } else if (DomainsMap.Spotify.includes(url.host)) {\n        query = query.replace(/intl-([a-zA-Z]+)\\//, '');\n        if (spotifyPlaylistRegex.test(query)) return resolver(QueryType.SPOTIFY_PLAYLIST, query);\n        if (spotifyAlbumRegex.test(query)) return resolver(QueryType.SPOTIFY_ALBUM, query);\n        if (spotifySongRegex.test(query)) return resolver(QueryType.SPOTIFY_SONG, query);\n        return resolver(fallbackSearchEngine, query);\n      } else if (DomainsMap.Vimeo.includes(url.host)) {\n        if (vimeoRegex.test(query)) return resolver(QueryType.VIMEO, query);\n        return resolver(fallbackSearchEngine, query);\n      } else if (DomainsMap.ReverbNation.includes(url.host)) {\n        if (reverbnationRegex.test(query)) return resolver(QueryType.REVERBNATION, query);\n        return resolver(fallbackSearchEngine, query);\n      } else if (DomainsMap.SoundCloud.includes(url.host)) {\n        if (soundcloudPlaylistRegex.test(query)) return resolver(QueryType.SOUNDCLOUD_PLAYLIST, query);\n        if (soundcloudTrackRegex.test(query)) return resolver(QueryType.SOUNDCLOUD_TRACK, query);\n        return resolver(fallbackSearchEngine, query);\n      } else if (DomainsMap.AppleMusic.includes(url.host)) {\n        if (appleMusicAlbumRegex.test(query)) return resolver(QueryType.APPLE_MUSIC_ALBUM, query);\n        if (appleMusicPlaylistRegex.test(query)) return resolver(QueryType.APPLE_MUSIC_PLAYLIST, query);\n        if (appleMusicSongRegex.test(query)) return resolver(QueryType.APPLE_MUSIC_SONG, query);\n        return resolver(fallbackSearchEngine, query);\n      } else {\n        return resolver(QueryType.ARBITRARY, query);\n      }\n    } catch {\n      return resolver(fallbackSearchEngine, query);\n    }\n  }\n\n  /**\n   * Parses vimeo id from url\n   * @param {string} query The query\n   * @returns {string}\n   */\n  static getVimeoID(query: string): string | null | undefined {\n    return QueryResolver.resolve(query).type === QueryType.VIMEO ? query.split('/').filter(Boolean).pop() : null;\n  }\n\n  static validateId(q: string) {\n    return youtubeVideoIdRegex.test(q);\n  }\n\n  static validateURL(q: string) {\n    return youtubeVideoURLRegex.test(q);\n  }\n}\n\nexport { QueryResolver };\n", "import { SnowflakeUtil } from 'discord.js';\n\nexport interface AsyncQueueAcquisitionOptions {\n  /**\n   * AbortSignal to cancel this entry\n   */\n  signal?: AbortSignal;\n}\n\nexport type AsyncQueueExceptionHandler = (exception: Error) => void;\n\nexport class AsyncQueue {\n  /**\n   * The queued entries\n   */\n  public entries: Array<AsyncQueueEntry> = [];\n\n  public exceptionHandler?: AsyncQueueExceptionHandler;\n\n  /**\n   * Clear entries queue\n   * @param consume Whether or not to consume all entries before clearing\n   */\n  public clear(consume = false) {\n    if (consume) {\n      this.entries.forEach((entry) => entry.consume());\n    }\n\n    this.entries = [];\n  }\n\n  /**\n   * The total number of entries in this queue. Returns `0` if no entries are available.\n   */\n  public get size() {\n    return this.entries.length;\n  }\n\n  /**\n   * Acquire an entry.\n   *\n   * @example // lock the queue\n   * const entry = asyncQueue.acquire();\n   * // wait until previous task is completed\n   * await entry.getTask();\n   * // do something expensive\n   * await performSomethingExpensive();\n   * // make sure to release the lock once done\n   * asyncQueue.release();\n   *\n   */\n  public acquire(options?: AsyncQueueAcquisitionOptions) {\n    const entry = new AsyncQueueEntry(this, options);\n\n    if (this.exceptionHandler) entry.getTask().catch(this.exceptionHandler);\n\n    if (this.entries.length === 0) {\n      this.entries.push(entry);\n      entry.consume();\n      return entry;\n    }\n\n    this.entries.push(entry);\n    return entry;\n  }\n\n  /**\n   * Release the current acquisition and move to next entry.\n   */\n  public release(): void {\n    if (!this.entries.length) return;\n\n    this.entries.shift();\n    this.entries[0]?.consume();\n  }\n\n  /**\n   * Cancel all entries\n   */\n  public cancelAll() {\n    this.entries.forEach((entry) => entry.cancel());\n  }\n\n  /**\n   * Remove the given entry from the queue\n   * @param entry The entry to remove\n   */\n  public removeEntry(entry: AsyncQueueEntry) {\n    const entryIdx = this.entries.indexOf(entry);\n\n    if (entryIdx !== -1) {\n      this.entries.splice(entryIdx, 1);\n      return true;\n    }\n\n    return false;\n  }\n}\n\nexport class AsyncQueueEntry {\n  public readonly id = SnowflakeUtil.generate().toString();\n  private readonly promise: Promise<void>;\n  public signal: AbortSignal | null = null;\n  public onAbort: (() => void) | null = null;\n  private resolve!: () => void;\n  private reject!: (err: Error) => void;\n\n  public constructor(public queue: AsyncQueue, public options?: AsyncQueueAcquisitionOptions) {\n    this.promise = new Promise((resolve, reject) => {\n      this.resolve = resolve;\n      this.reject = reject;\n    });\n\n    if (this.options?.signal) {\n      this.setAbortSignal(this.options.signal);\n    }\n  }\n\n  public setAbortSignal(signal: AbortSignal) {\n    if (signal.aborted) return;\n    this.signal = signal;\n    this.onAbort = () => {\n      this.queue.removeEntry(this);\n      this.cancel();\n    };\n\n    this.signal.addEventListener('abort', this.onAbort);\n  }\n\n  public consume() {\n    this.cleanup();\n    this.resolve();\n  }\n\n  public release() {\n    this.consume();\n    this.queue.release();\n  }\n\n  public cancel() {\n    this.cleanup();\n    this.reject(new Error('Cancelled'));\n  }\n\n  public cleanup() {\n    if (this.onAbort) this.signal?.removeEventListener('abort', this.onAbort);\n    this.signal = null;\n    this.onAbort = null;\n  }\n\n  public getTask() {\n    return this.promise;\n  }\n}\n", "import { Readable } from 'stream';\nimport { FiltersName, QueueFilters } from '../types/types';\nimport { AudioFilters } from '../utils/AudioFilters';\nimport { GuildQueue, GuildQueueEvent } from './GuildQueue';\nimport { BiquadFilters, Equalizer, EqualizerBand, PCMFilters } from '@discord-player/equalizer';\nimport { FFmpegStreamOptions, createFFmpegStream } from '../utils/FFmpegStream';\nimport { Exceptions } from '../errors';\n\ntype Filters = keyof typeof AudioFilters.filters;\n\nconst makeBands = (arr: number[]) => {\n  return Array.from(\n    {\n      length: Equalizer.BAND_COUNT,\n    },\n    (_, i) => ({\n      band: i,\n      gain: arr[i] ? arr[i] / 30 : 0,\n    }),\n  ) as EqualizerBand[];\n};\n\ntype EQPreset = {\n  Flat: EqualizerBand[];\n  Classical: EqualizerBand[];\n  Club: EqualizerBand[];\n  Dance: EqualizerBand[];\n  FullBass: EqualizerBand[];\n  FullBassTreble: EqualizerBand[];\n  FullTreble: EqualizerBand[];\n  Headphones: EqualizerBand[];\n  LargeHall: EqualizerBand[];\n  Live: EqualizerBand[];\n  Party: EqualizerBand[];\n  Pop: EqualizerBand[];\n  Reggae: EqualizerBand[];\n  Rock: EqualizerBand[];\n  Ska: EqualizerBand[];\n  Soft: EqualizerBand[];\n  SoftRock: EqualizerBand[];\n  Techno: EqualizerBand[];\n};\n\nexport const EqualizerConfigurationPreset: Readonly<EQPreset> = Object.freeze({\n  Flat: makeBands([]),\n  Classical: makeBands([\n    -1.11022e-15, -1.11022e-15, -1.11022e-15, -1.11022e-15, -1.11022e-15, -1.11022e-15, -7.2, -7.2, -7.2, -9.6,\n  ]),\n  Club: makeBands([-1.11022e-15, -1.11022e-15, 8.0, 5.6, 5.6, 5.6, 3.2, -1.11022e-15, -1.11022e-15, -1.11022e-15]),\n  Dance: makeBands([9.6, 7.2, 2.4, -1.11022e-15, -1.11022e-15, -5.6, -7.2, -7.2, -1.11022e-15, -1.11022e-15]),\n  FullBass: makeBands([-8.0, 9.6, 9.6, 5.6, 1.6, -4.0, -8.0, -10.4, -11.2, -11.2]),\n  FullBassTreble: makeBands([7.2, 5.6, -1.11022e-15, -7.2, -4.8, 1.6, 8.0, 11.2, 12.0, 12.0]),\n  FullTreble: makeBands([-9.6, -9.6, -9.6, -4.0, 2.4, 11.2, 16.0, 16.0, 16.0, 16.8]),\n  Headphones: makeBands([4.8, 11.2, 5.6, -3.2, -2.4, 1.6, 4.8, 9.6, 12.8, 14.4]),\n  LargeHall: makeBands([10.4, 10.4, 5.6, 5.6, -1.11022e-15, -4.8, -4.8, -4.8, -1.11022e-15, -1.11022e-15]),\n  Live: makeBands([-4.8, -1.11022e-15, 4.0, 5.6, 5.6, 5.6, 4.0, 2.4, 2.4, 2.4]),\n  Party: makeBands([\n    7.2, 7.2, -1.11022e-15, -1.11022e-15, -1.11022e-15, -1.11022e-15, -1.11022e-15, -1.11022e-15, 7.2, 7.2,\n  ]),\n  Pop: makeBands([-1.6, 4.8, 7.2, 8.0, 5.6, -1.11022e-15, -2.4, -2.4, -1.6, -1.6]),\n  Reggae: makeBands([\n    -1.11022e-15, -1.11022e-15, -1.11022e-15, -5.6, -1.11022e-15, 6.4, 6.4, -1.11022e-15, -1.11022e-15, -1.11022e-15,\n  ]),\n  Rock: makeBands([8.0, 4.8, -5.6, -8.0, -3.2, 4.0, 8.8, 11.2, 11.2, 11.2]),\n  Ska: makeBands([-2.4, -4.8, -4.0, -1.11022e-15, 4.0, 5.6, 8.8, 9.6, 11.2, 9.6]),\n  Soft: makeBands([4.8, 1.6, -1.11022e-15, -2.4, -1.11022e-15, 4.0, 8.0, 9.6, 11.2, 12.0]),\n  SoftRock: makeBands([4.0, 4.0, 2.4, -1.11022e-15, -4.0, -5.6, -3.2, -1.11022e-15, 2.4, 8.8]),\n  Techno: makeBands([8.0, 5.6, -1.11022e-15, -5.6, -4.8, -1.11022e-15, 8.0, 9.6, 9.6, 8.8]),\n});\n\nexport class FFmpegFilterer<Meta = unknown> {\n  #ffmpegFilters: Filters[] = [];\n  #inputArgs: string[] = [];\n  public constructor(public af: GuildQueueAudioFilters<Meta>) {}\n\n  /**\n   * Indicates whether ffmpeg may be skipped\n   */\n  public get skippable() {\n    return !!this.af.queue.player.options.skipFFmpeg;\n  }\n\n  #setFilters(filters: Filters[]) {\n    const { queue } = this.af;\n    // skip if filters are the same\n    if (filters.every((f) => this.#ffmpegFilters.includes(f)) && this.#ffmpegFilters.every((f) => filters.includes(f)))\n      return Promise.resolve(false);\n    const ignoreFilters =\n      this.filters.some((ff) => ff === 'nightcore' || ff === 'vaporwave') &&\n      !filters.some((ff) => ff === 'nightcore' || ff === 'vaporwave');\n    const seekTime = queue.node.getTimestamp(ignoreFilters)?.current.value || 0;\n    const prev = this.#ffmpegFilters.slice();\n    this.#ffmpegFilters = [...new Set(filters)];\n\n    return this.af.triggerReplay(seekTime).then((t) => {\n      queue.emit(GuildQueueEvent.AudioFiltersUpdate, queue, prev, this.#ffmpegFilters.slice());\n      return t;\n    });\n  }\n\n  /**\n   * Set input args for FFmpeg\n   */\n  public setInputArgs(args: string[]) {\n    if (!args.every((arg) => typeof arg === 'string'))\n      throw Exceptions.ERR_INVALID_ARG_TYPE('args', 'Array<string>', 'invalid item(s)');\n    this.#inputArgs = args;\n  }\n\n  /**\n   * Get input args\n   */\n  public get inputArgs() {\n    return this.#inputArgs;\n  }\n\n  /**\n   * Get encoder args\n   */\n  public get encoderArgs() {\n    if (!this.filters.length) return [];\n\n    return ['-af', this.toString()];\n  }\n\n  /**\n   * Get final ffmpeg args\n   */\n  public get args() {\n    return this.inputArgs.concat(this.encoderArgs);\n  }\n\n  /**\n   * Create ffmpeg stream\n   * @param source The stream source\n   * @param options The stream options\n   */\n  public createStream(source: string | Readable, options: FFmpegStreamOptions) {\n    if (this.#inputArgs.length) options.encoderArgs = [...this.#inputArgs, ...(options.encoderArgs || [])];\n    return createFFmpegStream(source, options);\n  }\n\n  /**\n   * Set ffmpeg filters\n   * @param filters The filters\n   */\n  public setFilters(filters: Filters[] | Record<Filters, boolean> | string[] | boolean) {\n    let _filters: Filters[] = [];\n    if (typeof filters === 'boolean') {\n      _filters = !filters ? [] : (Object.keys(AudioFilters.filters) as Filters[]);\n    } else if (Array.isArray(filters)) {\n      _filters = filters as Filters[];\n    } else {\n      _filters = Object.entries(filters)\n        .filter((res) => res[1] === true)\n        .map((m) => m[0]) as Filters[];\n    }\n\n    return this.#setFilters(_filters);\n  }\n\n  /**\n   * Currently active ffmpeg filters\n   */\n  public get filters() {\n    return this.#ffmpegFilters;\n  }\n\n  public set filters(filters: Filters[]) {\n    this.setFilters(filters);\n  }\n\n  /**\n   * Toggle given ffmpeg filter(s)\n   * @param filters The filter(s)\n   */\n  public toggle(filters: Filters[] | Filters) {\n    if (!Array.isArray(filters)) filters = [filters];\n    const fresh: Filters[] = [];\n\n    filters.forEach((f) => {\n      if (this.filters.includes(f)) return;\n      fresh.push(f);\n    });\n\n    return this.#setFilters(this.#ffmpegFilters.filter((r) => !filters.includes(r)).concat(fresh));\n  }\n\n  /**\n   * Set default filters\n   * @param ff Filters list\n   */\n  public setDefaults(ff: Filters[]) {\n    this.#ffmpegFilters = ff;\n  }\n\n  /**\n   * Get list of enabled filters\n   */\n  public getFiltersEnabled() {\n    return this.#ffmpegFilters;\n  }\n\n  /**\n   * Get list of disabled filters\n   */\n  public getFiltersDisabled() {\n    return AudioFilters.names.filter((f) => !this.#ffmpegFilters.includes(f));\n  }\n\n  /**\n   * Check if the given filter is enabled\n   * @param filter The filter\n   */\n  public isEnabled<T extends Filters>(filter: T): boolean {\n    return this.#ffmpegFilters.includes(filter);\n  }\n\n  /**\n   * Check if the given filter is disabled\n   * @param filter The filter\n   */\n  public isDisabled<T extends Filters>(filter: T): boolean {\n    return !this.isEnabled(filter);\n  }\n\n  /**\n   * Check if the given filter is a valid filter\n   * @param filter The filter to test\n   */\n  public isValidFilter(filter: string): filter is FiltersName {\n    return AudioFilters.has(filter as Filters);\n  }\n\n  /**\n   * Convert current filters to array\n   */\n  public toArray() {\n    return this.filters.map((filter) => AudioFilters.get(filter));\n  }\n\n  /**\n   * Convert current filters to JSON object\n   */\n  public toJSON() {\n    const obj = {} as Record<keyof QueueFilters, string>;\n\n    this.filters.forEach((filter) => (obj[filter] = AudioFilters.get(filter)));\n\n    return obj;\n  }\n\n  /**\n   * String representation of current filters\n   */\n  public toString() {\n    return AudioFilters.create(this.filters);\n  }\n}\n\nexport interface GuildQueueAFiltersCache {\n  equalizer: EqualizerBand[];\n  biquad: BiquadFilters | null;\n  filters: PCMFilters[];\n  volume: number;\n  sampleRate: number;\n}\n\nexport class GuildQueueAudioFilters<Meta = unknown> {\n  public graph = new AFilterGraph<Meta>(this);\n  public ffmpeg = new FFmpegFilterer<Meta>(this);\n  public equalizerPresets = EqualizerConfigurationPreset;\n  public _lastFiltersCache: GuildQueueAFiltersCache = {\n    biquad: null,\n    equalizer: [],\n    filters: [],\n    volume: 100,\n    sampleRate: -1,\n  };\n  public constructor(public queue: GuildQueue<Meta>) {\n    if (typeof this.queue.options.volume === 'number') {\n      this._lastFiltersCache.volume = this.queue.options.volume;\n    }\n  }\n\n  // TODO: enable this in the future\n  // public get ffmpeg(): FFmpegFilterer<Meta> | null {\n  //     if (this.queue.player.options.skipFFmpeg) {\n  //         if (this.#ffmpeg) this.#ffmpeg = null;\n  //         return null;\n  //     }\n\n  //     if (!this.#ffmpeg) {\n  //         this.#ffmpeg = new FFmpegFilterer<Meta>(this);\n  //     }\n\n  //     return this.#ffmpeg;\n  // }\n\n  /**\n   * Volume transformer\n   */\n  public get volume() {\n    return this.queue.dispatcher?.dsp?.volume || null;\n  }\n\n  /**\n   * 15 Band Equalizer\n   */\n  public get equalizer() {\n    return this.queue.dispatcher?.equalizer || null;\n  }\n\n  /**\n   * Digital biquad filters\n   */\n  public get biquad() {\n    return this.queue.dispatcher?.biquad || null;\n  }\n\n  /**\n   * DSP filters\n   */\n  public get filters() {\n    return this.queue.dispatcher?.filters || null;\n  }\n\n  /**\n   * Audio resampler\n   */\n  public get resampler() {\n    return this.queue.dispatcher?.resampler || null;\n  }\n\n  /**\n   * Replay current track in transition mode\n   * @param seek The duration to seek to\n   */\n  public async triggerReplay(seek = 0) {\n    if (!this.queue.currentTrack) return false;\n    const entry = this.queue.node.tasksQueue.acquire();\n    try {\n      await entry.getTask();\n      await this.queue.node.play(this.queue.currentTrack, {\n        queue: false,\n        seek,\n        transitionMode: true,\n      });\n      this.queue.node.tasksQueue.release();\n      return true;\n    } catch {\n      this.queue.node.tasksQueue.release();\n      return false;\n    }\n  }\n}\n\nexport class AFilterGraph<Meta = unknown> {\n  public constructor(public af: GuildQueueAudioFilters<Meta>) {}\n\n  public get ffmpeg() {\n    return this.af.ffmpeg?.filters ?? [];\n  }\n\n  public get equalizer() {\n    return (this.af.equalizer?.bandMultipliers || []).map((m, i) => ({\n      band: i,\n      gain: m,\n    })) as EqualizerBand[];\n  }\n\n  public get biquad() {\n    return (this.af.biquad?.getFilterName() as Exclude<BiquadFilters, number> | null) || null;\n  }\n\n  public get filters() {\n    return this.af.filters?.filters || [];\n  }\n\n  public get volume() {\n    return this.af.volume;\n  }\n\n  public get resampler() {\n    return this.af.resampler;\n  }\n\n  public dump(): FilterGraph {\n    return {\n      ffmpeg: this.ffmpeg,\n      equalizer: this.equalizer,\n      biquad: this.biquad,\n      filters: this.filters,\n      sampleRate: this.resampler?.targetSampleRate || this.resampler?.sampleRate || 48000,\n      volume: this.volume?.volume ?? 100,\n    };\n  }\n}\n\nexport interface FilterGraph {\n  ffmpeg: Filters[];\n  equalizer: EqualizerBand[];\n  biquad: Exclude<BiquadFilters, number> | null;\n  filters: PCMFilters[];\n  volume: number;\n  sampleRate: number;\n}\n", "import type { Duplex, Readable } from 'stream';\nimport { FFmpeg } from '@discord-player/ffmpeg';\n\n// @ts-ignore\nimport * as prism from 'prism-media';\n\nexport interface FFmpegStreamOptions {\n  fmt?: string;\n  encoderArgs?: string[];\n  seek?: number;\n  skip?: boolean;\n  cookies?: string;\n  useLegacyFFmpeg?: boolean;\n}\n\nconst getFFmpegProvider = (legacy = false) =>\n  legacy ? (prism as typeof prism & { default: typeof prism }).default?.FFmpeg || prism.FFmpeg : FFmpeg;\n\nconst resolveArgs = (config: Record<string, string | number | null | undefined>): string[] => {\n  return Object.entries(config).reduce((acc, [key, value]) => {\n    if (value == null) return acc;\n    acc.push(`-${key}`, String(value));\n    return acc;\n  }, [] as string[]);\n};\n\nexport function FFMPEG_ARGS_STRING(stream: string, fmt?: string, cookies?: string) {\n  const args = resolveArgs({\n    reconnect: 1,\n    reconnect_streamed: 1,\n    reconnect_delay_max: 5,\n    i: stream,\n    analyzeduration: 0,\n    loglevel: 0,\n    ar: 48000,\n    ac: 2,\n    f: `${typeof fmt === 'string' ? fmt : 's16le'}`,\n    acodec: fmt === 'opus' ? 'libopus' : null,\n    cookies: typeof cookies === 'string' ? (!cookies.includes(' ') ? cookies : `\"${cookies}\"`) : null,\n  });\n\n  return args;\n}\n\nexport function FFMPEG_ARGS_PIPED(fmt?: string) {\n  const args = resolveArgs({\n    analyzeduration: 0,\n    loglevel: 0,\n    ar: 48000,\n    ac: 2,\n    f: `${typeof fmt === 'string' ? fmt : 's16le'}`,\n    acodec: fmt === 'opus' ? 'libopus' : null,\n  });\n\n  return args;\n}\n\n/**\n * Creates FFmpeg stream\n * @param stream The source stream\n * @param options FFmpeg stream options\n */\nexport function createFFmpegStream(stream: Readable | Duplex | string, options?: FFmpegStreamOptions) {\n  if (options?.skip && typeof stream !== 'string') return stream;\n  options ??= {};\n  const args =\n    typeof stream === 'string'\n      ? FFMPEG_ARGS_STRING(stream, options.fmt, options.cookies)\n      : FFMPEG_ARGS_PIPED(options.fmt);\n\n  if (!Number.isNaN(options.seek)) args.unshift('-ss', String(options.seek));\n  if (Array.isArray(options.encoderArgs)) args.push(...options.encoderArgs);\n\n  const FFMPEG = getFFmpegProvider(!!options.useLegacyFFmpeg);\n\n  const transcoder: Duplex = new FFMPEG({ shell: false, args });\n\n  transcoder.on('close', () => transcoder.destroy());\n\n  if (typeof stream !== 'string') {\n    stream.on('error', () => transcoder.destroy());\n    // eslint-disable-next-line @typescript-eslint/no-explicit-any\n    stream.pipe(transcoder as any);\n  }\n\n  return transcoder;\n}\n", "import { GuildQueue } from './GuildQueue';\n\nexport interface GuildQueueStatisticsMetadata {\n  latency: {\n    eventLoop: number;\n    voiceConnection: number;\n  };\n  status: {\n    buffering: boolean;\n    playing: boolean;\n    paused: boolean;\n    idle: boolean;\n  };\n  tracksCount: number;\n  historySize: number;\n  extractors: number;\n  listeners: number;\n  memoryUsage: NodeJS.MemoryUsage;\n  versions: {\n    node: string;\n    player: string;\n  };\n}\n\nexport class GuildQueueStatistics<Meta = unknown> {\n  public constructor(public queue: GuildQueue<Meta>) {}\n\n  /**\n   * Generate statistics of this queue\n   */\n  public generate() {\n    return {\n      latency: {\n        eventLoop: this.queue.player.eventLoopLag,\n        voiceConnection: this.queue.ping,\n      },\n      status: {\n        buffering: this.queue.node.isBuffering(),\n        playing: this.queue.node.isPlaying(),\n        paused: this.queue.node.isPaused(),\n        idle: this.queue.node.isIdle(),\n      },\n      tracksCount: this.queue.tracks.size,\n      historySize: this.queue.history.tracks.size,\n      extractors: this.queue.player.extractors.size,\n      listeners: this.queue.guild.members.me?.voice.channel?.members.filter((m) => !m.user.bot).size || 0,\n      memoryUsage: process.memoryUsage(),\n      versions: {\n        node: process.version,\n        player: '7.0.0-dev.5',\n      },\n    } as GuildQueueStatisticsMetadata;\n  }\n}\n", "import { Exceptions } from '../errors';\nimport { LrcGetResult, LrcSearchResult } from '../lrclib/LrcLib';\nimport type { GuildQueue } from './GuildQueue';\n\nexport type LyricsData = Map<number, string>;\nexport type Unsubscribe = () => void;\nexport type LyricsCallback = (lyrics: string, timestamp: number) => unknown;\nexport type LyricsAt = { timestamp: number; line: string };\n\nconst timestampPattern = /\\[(\\d{2}):(\\d{2})\\.(\\d{2})\\]/;\n\nexport class SyncedLyricsProvider {\n  #loop: NodeJS.Timeout | null = null;\n  #callback: LyricsCallback | null = null;\n  #onUnsubscribe: Unsubscribe | null = null;\n\n  public interval = 100;\n  public readonly lyrics: LyricsData = new Map();\n\n  public constructor(public readonly queue: GuildQueue, public readonly raw?: LrcGetResult | LrcSearchResult) {\n    if (raw?.syncedLyrics) this.load(raw?.syncedLyrics);\n  }\n\n  public isSubscribed() {\n    return this.#callback !== null;\n  }\n\n  public load(lyrics: string) {\n    if (!lyrics) throw Exceptions.ERR_NOT_EXISTING('syncedLyrics');\n\n    this.lyrics.clear();\n    this.unsubscribe();\n\n    const lines = lyrics.split('\\n');\n\n    for (const line of lines) {\n      const match = line.match(timestampPattern);\n\n      if (match) {\n        const [, minutes, seconds, milliseconds] = match;\n        const timestamp = parseInt(minutes) * 60 * 1000 + parseInt(seconds) * 1000 + parseInt(milliseconds);\n\n        this.lyrics.set(timestamp, line.replace(timestampPattern, '').trim());\n      }\n    }\n  }\n\n  /**\n   * Returns the lyrics at a specific time or at the closest time (\u00B12 seconds)\n   * @param time The time in milliseconds\n   */\n  public at(time: number): LyricsAt | null {\n    const lowestTime = this.lyrics.keys().next().value;\n    if (lowestTime == null || time < lowestTime) return null;\n    if (this.lyrics.has(time)) return { line: this.lyrics.get(time) as string, timestamp: time };\n\n    const keys = Array.from(this.lyrics.keys());\n\n    const closest = keys.reduce((a, b) => (Math.abs(b - time) < Math.abs(a - time) ? b : a));\n\n    if (closest > time) return null;\n\n    if (Math.abs(closest - time) > 2000) return null;\n\n    const line = this.lyrics.get(closest);\n\n    if (!line) return null;\n\n    return { timestamp: closest, line };\n  }\n\n  /**\n   * Callback for the lyrics change.\n   * @param callback The callback function\n   */\n  public onChange(callback: LyricsCallback) {\n    this.#callback = callback;\n  }\n\n  /**\n   * Callback to detect when the provider is unsubscribed.\n   * @param callback The callback function\n   */\n  public onUnsubscribe(callback: Unsubscribe) {\n    this.#onUnsubscribe = callback;\n  }\n\n  /**\n   * Unsubscribes from the queue.\n   */\n  public unsubscribe() {\n    if (this.#loop) clearInterval(this.#loop);\n    if (this.#onUnsubscribe) this.#onUnsubscribe();\n\n    this.#callback = null;\n    this.#onUnsubscribe = null;\n    this.#loop = null;\n  }\n\n  /**\n   * Subscribes to the queue to monitor the current time.\n   * @returns The unsubscribe function\n   */\n  public subscribe(): Unsubscribe {\n    if (this.#loop) return () => this.unsubscribe();\n\n    this.#createLoop();\n\n    return () => this.unsubscribe();\n  }\n\n  /**\n   * Pauses the lyrics provider.\n   */\n  public pause() {\n    const hasLoop = this.#loop !== null;\n\n    if (hasLoop) {\n      clearInterval(this.#loop!);\n      this.#loop = null;\n    }\n\n    return hasLoop;\n  }\n\n  /**\n   * Resumes the lyrics provider.\n   */\n  public resume() {\n    const hasLoop = this.#loop !== null;\n\n    if (!hasLoop) this.#createLoop();\n\n    return !hasLoop;\n  }\n\n  #createLoop() {\n    if (!this.#callback) return;\n    if (this.#loop) clearInterval(this.#loop);\n\n    let lastValue: LyricsAt | null = null;\n\n    this.#loop = setInterval(() => {\n      if (this.queue.deleted) return this.unsubscribe();\n\n      if (!this.#callback || !this.queue.isPlaying()) return;\n\n      const time = this.queue.node.getTimestamp();\n      if (!time) return;\n\n      const lyrics = this.at(time.current.value);\n\n      if (!lyrics) return;\n\n      if (lastValue !== null && lyrics.line === lastValue.line && lyrics.timestamp === lastValue.timestamp) return;\n\n      lastValue = lyrics;\n\n      this.#callback(lyrics.line, lyrics.timestamp);\n    }, this.interval).unref();\n  }\n}\n", "import { setTimeout } from 'timers/promises';\nimport { AsyncQueue } from './AsyncQueue';\n\nexport type RequestEntity = () => Promise<Response>;\n\nexport class SequentialBucket {\n  public limit = 1;\n  public remaining = 1;\n  public resetAfter = 0;\n  public queue = new AsyncQueue();\n  public MAX_RETRIES = 5;\n\n  /**\n   * Checks if the bucket is rate limited.\n   */\n  public isRateLimited() {\n    return this.remaining <= 0 && Date.now() < this.resetAfter;\n  }\n\n  /**\n   * Enqueues a request.\n   * @param req The request function to enqueue\n   */\n  public async enqueue(req: RequestEntity) {\n    const entry = this.queue.acquire();\n    await entry.getTask();\n\n    try {\n      return this._request(req);\n    } finally {\n      entry.release();\n    }\n  }\n\n  private async _request(req: RequestEntity, retries = 0): Promise<Response> {\n    while (this.isRateLimited()) {\n      const reset = this.resetAfter - Date.now();\n      await setTimeout(reset);\n    }\n\n    let pass = false;\n\n    try {\n      const res = await req();\n\n      this._patchHeaders(res);\n\n      if (res.status === 429) {\n        const reset = this.resetAfter - Date.now();\n        await setTimeout(reset);\n        return this._request(req);\n      }\n\n      if (!res.ok) {\n        let err: Error;\n\n        try {\n          const body: {\n            code: number;\n            name: string;\n            message: string;\n          } = await res.json();\n\n          const error = new Error(body.message) as Error & { code: number };\n\n          error.name = body.name;\n          error.code = body.code;\n\n          err = error;\n        } catch {\n          err = new Error(`HTTP Error: ${res.status} ${res.statusText}`);\n        }\n\n        pass = true;\n\n        throw err;\n      }\n\n      return res;\n    } catch (e) {\n      if (pass) throw e;\n\n      const badReq = e instanceof Error && /Error: 4[0-9]{2}/.test(e.message);\n\n      if (!badReq && retries < this.MAX_RETRIES) {\n        return this._request(req, ++retries);\n      }\n\n      throw e;\n    }\n  }\n\n  private _patchHeaders(res: Response) {\n    const limit = Number(res.headers.get('X-RateLimit-Limit'));\n    const remaining = Number(res.headers.get('X-RateLimit-Remaining'));\n    const resetAfter = Number(res.headers.get('X-RateLimit-Reset')) * 1000 + Date.now();\n\n    if (!Number.isNaN(limit)) this.limit = limit;\n    if (!Number.isNaN(remaining)) this.remaining = remaining;\n    if (!Number.isNaN(resetAfter)) this.resetAfter = resetAfter;\n  }\n}\n", "import { Exceptions } from '../errors';\nimport type { Player } from '../Player';\nimport { Util } from '../utils/Util';\nimport { SequentialBucket } from '../utils/SequentialBucket';\n\nexport interface LrcSearchParams {\n  /**\n   * The query to search for. Either this or trackName is required.\n   */\n  q?: string;\n  /**\n   * The track name to search for. Either this or query is required.\n   */\n  trackName?: string;\n  /**\n   * The artist name\n   */\n  artistName?: string;\n  /**\n   * The album name\n   */\n  albumName?: string;\n}\n\nexport interface LrcGetParams extends Required<Omit<LrcSearchParams, 'query'>> {\n  /**\n   * The duration of the track\n   */\n  duration: number;\n}\n\nconst toSnakeCase = (obj: Record<string, string>): Record<string, string> => {\n  const snakeObj: Record<string, string> = {};\n\n  for (const [key, value] of Object.entries(obj)) {\n    if (value == null) continue;\n    const newKey = key.replace(/[A-Z]/g, (letter) => `_${letter.toLowerCase()}`);\n    snakeObj[newKey] = value;\n  }\n\n  return snakeObj;\n};\n\n// eslint-disable-next-line @typescript-eslint/no-explicit-any\nconst createQuery = (params: any) => new URLSearchParams(toSnakeCase(params)).toString();\n\nexport interface LrcSearchResult {\n  /**\n   * The track id\n   */\n  id: number;\n  /**\n   * The track name\n   */\n  name: string;\n  /**\n   * The artist name\n   */\n  trackName: string;\n  /**\n   * The album name\n   */\n  artistName: string;\n  /**\n   * The album name\n   */\n  albumName: string;\n  /**\n   * The duration of the track\n   */\n  duration: number;\n  /**\n   * The release date of the track\n   */\n  instrumental: boolean;\n  /**\n   * The release date of the track\n   */\n  plainLyrics: string;\n  /**\n   * The release date of the track\n   */\n  syncedLyrics?: string;\n}\n\nexport type LrcGetResult = Omit<LrcSearchResult, 'name'>;\n\nexport class LrcLib {\n  /**\n   * The API URL\n   */\n  public api = 'https://lrclib.net/api';\n  /**\n   * The request timeout. Default is 15 seconds.\n   */\n  public timeout = 15_000;\n  /**\n   * The request bucket\n   */\n  public bucket = new SequentialBucket();\n\n  /**\n   * Creates a new LrcLib instance\n   * @param {Player} player The player instance\n   */\n  public constructor(public readonly player: Player) {}\n\n  /**\n   * Sets the request timeout\n   * @param {number} timeout The timeout in milliseconds\n   */\n  public setRequestTimeout(timeout: number) {\n    this.timeout = timeout;\n  }\n\n  /**\n   * Sets the retry limit. Default is 5.\n   * @param {number} limit The retry limit\n   */\n  public setRetryLimit(limit: number) {\n    this.bucket.MAX_RETRIES = limit;\n  }\n\n  /**\n   * Gets lyrics\n   * @param params The get params\n   */\n  public get(params: LrcGetParams) {\n    const path = `get?${createQuery(params)}`;\n\n    return this.request<LrcSearchResult>(path);\n  }\n\n  /**\n   * Gets lyrics by ID\n   * @param id The lyrics ID\n   */\n  public getById(id: `${number}` | number) {\n    return this.request<LrcSearchResult>(`get/${id}`);\n  }\n\n  /**\n   * Gets cached lyrics\n   * @param params The get params\n   */\n  public getCached(params: LrcGetParams) {\n    const path = `get-cached?${createQuery(params)}`;\n\n    return this.request<LrcSearchResult>(path);\n  }\n\n  /**\n   * Searches for lyrics\n   * @param params The search params\n   */\n  public search(params: LrcSearchParams) {\n    if (!params.q && !params.trackName) {\n      throw Exceptions.ERR_INVALID_ARG_TYPE(\n        'one of q or trackName',\n        'string',\n        [String(params.q), String(params.trackName)].join(', '),\n      );\n    }\n\n    const path = `search?${createQuery(params)}`;\n\n    return this.request<LrcSearchResult[]>(path);\n  }\n\n  /**\n   * Requests the API\n   * @param path The path\n   * @param options The request options\n   */\n  public async request<T>(path: string, options?: RequestInit): Promise<T> {\n    let timeout: NodeJS.Timeout | null = null;\n\n    const dispatcher = () => {\n      const controller = new AbortController();\n\n      timeout = setTimeout(() => {\n        controller.abort();\n      }, this.timeout).unref();\n\n      const { name, version } = Util.getRuntime();\n\n      const runtimeVersion = name === 'unknown' ? version : `${name}/${version}`;\n\n      const init: RequestInit = {\n        method: 'GET',\n        redirect: 'follow',\n        signal: controller.signal,\n        ...options,\n        headers: {\n          'User-Agent': `Discord-Player/${this.player.version} ${runtimeVersion ?? ''}`.trimEnd(),\n          'Content-Type': 'application/json',\n          ...options?.headers,\n        },\n      };\n\n      this.player.debug(`[LrcLib] Requesting ${path}`);\n\n      return fetch(`${this.api}${path.startsWith('/') ? path : '/' + path}`, init);\n    };\n\n    const res = await this.bucket.enqueue(dispatcher);\n\n    if (timeout) clearTimeout(timeout);\n\n    return res.json();\n  }\n}\n", "import { VoiceChannel, StageChannel, Snowflake } from 'discord.js';\nimport {\n  DiscordGatewayAdapterCreator,\n  joinVoiceChannel,\n  VoiceConnection,\n  getVoiceConnection,\n  VoiceConnectionStatus,\n  AudioPlayer,\n} from 'discord-voip';\nimport { StreamDispatcher } from './StreamDispatcher';\nimport { Collection } from '@discord-player/utils';\nimport { GuildQueue } from '../queue';\nimport type { Player } from '../Player';\nimport { Exceptions } from '../errors';\n\nclass VoiceUtils {\n  /**\n   * Voice connection cache to store voice connections of the Player components.\n   * This property is deprecated and will be removed in the future.\n   * It only exists for compatibility reasons.\n   * @deprecated\n   */\n  public cache: Collection<Snowflake, StreamDispatcher> = new Collection<Snowflake, StreamDispatcher>();\n\n  /**\n   * The voice utils constructor\n   */\n  constructor(public player: Player) {}\n\n  /**\n   * Joins a voice channel, creating basic stream dispatch manager\n   * @param {StageChannel|VoiceChannel} channel The voice channel\n   * @param {object} [options] Join options\n   * @returns {Promise<StreamDispatcher>}\n   */\n  public async connect(\n    channel: VoiceChannel | StageChannel,\n    options?: {\n      deaf?: boolean;\n      maxTime?: number;\n      queue: GuildQueue;\n      audioPlayer?: AudioPlayer;\n      group?: string;\n    },\n  ): Promise<StreamDispatcher> {\n    if (!options?.queue) throw Exceptions.ERR_NO_GUILD_QUEUE();\n    const conn = await this.join(channel, options);\n    const sub = new StreamDispatcher(conn, channel, options.queue, options.maxTime, options.audioPlayer);\n    return sub;\n  }\n\n  /**\n   * Joins a voice channel\n   * @param {StageChannel|VoiceChannel} [channel] The voice/stage channel to join\n   * @param {object} [options] Join options\n   * @returns {VoiceConnection}\n   */\n  public async join(\n    channel: VoiceChannel | StageChannel,\n    options?: {\n      deaf?: boolean;\n      maxTime?: number;\n      group?: string;\n    },\n  ) {\n    const existingConnection = this.getConnection(channel.guild.id, options?.group);\n\n    if (\n      existingConnection?.joinConfig.channelId === channel?.id &&\n      existingConnection.state.status !== VoiceConnectionStatus.Destroyed\n    ) {\n      return existingConnection;\n    }\n\n    const conn = joinVoiceChannel({\n      guildId: channel.guild.id,\n      channelId: channel.id,\n      adapterCreator: channel.guild.voiceAdapterCreator as unknown as DiscordGatewayAdapterCreator,\n      selfDeaf: Boolean(options?.deaf),\n      debug: this.player.events.listenerCount('debug') > 0,\n      group: options?.group,\n    });\n\n    return conn;\n  }\n\n  /**\n   * Disconnects voice connection\n   * @param {VoiceConnection} connection The voice connection\n   * @returns {void}\n   */\n  public disconnect(connection: VoiceConnection | StreamDispatcher) {\n    if (connection instanceof StreamDispatcher) connection = connection.voiceConnection;\n\n    try {\n      if (connection.state.status !== VoiceConnectionStatus.Destroyed) return connection.destroy();\n    } catch {\n      //\n    }\n  }\n\n  /**\n   * Returns Discord Player voice connection\n   * @param {Snowflake} guild The guild id\n   * @returns {StreamDispatcher}\n   */\n  public getConnection(guild: Snowflake, group?: string) {\n    return getVoiceConnection(guild, group);\n  }\n}\n\nexport { VoiceUtils };\n", "import { Player } from '../Player';\nimport { SearchResult } from '../fabric/SearchResult';\nimport { Track } from '../fabric/Track';\nimport { User } from 'discord.js';\nimport { SearchQueryType } from '../types/types';\n\nexport interface QueryCacheOptions {\n  checkInterval?: number;\n}\n\n// 5h\nconst DEFAULT_EXPIRY_TIMEOUT = 18_000_000;\n\nexport interface QueryCacheProvider<T> {\n  getData(): Promise<DiscordPlayerQueryResultCache<T>[]>;\n  addData(data: SearchResult): Promise<void>;\n  resolve(context: QueryCacheResolverContext): Promise<SearchResult>;\n}\n\nexport class QueryCache implements QueryCacheProvider<Track> {\n  #defaultCache = new Map<string, DiscordPlayerQueryResultCache<Track>>();\n  public timer: NodeJS.Timer;\n  public constructor(\n    public player: Player,\n    public options: QueryCacheOptions = {\n      checkInterval: DEFAULT_EXPIRY_TIMEOUT,\n    },\n  ) {\n    this.timer = setInterval(this.cleanup.bind(this), this.checkInterval).unref();\n  }\n\n  public get checkInterval() {\n    return this.options.checkInterval ?? DEFAULT_EXPIRY_TIMEOUT;\n  }\n\n  public async cleanup() {\n    for (const [id, value] of this.#defaultCache) {\n      if (value.hasExpired()) {\n        this.#defaultCache.delete(id);\n      }\n    }\n  }\n\n  public async clear() {\n    this.#defaultCache.clear();\n  }\n\n  public async getData() {\n    return [...this.#defaultCache.values()];\n  }\n\n  public async addData(data: SearchResult) {\n    data.tracks.forEach((d) => {\n      if (this.#defaultCache.has(d.url)) return;\n      this.#defaultCache.set(d.url, new DiscordPlayerQueryResultCache(d));\n    });\n  }\n\n  public async resolve(context: QueryCacheResolverContext) {\n    const result = this.#defaultCache.get(context.query);\n    if (!result)\n      return new SearchResult(this.player, {\n        query: context.query,\n        requestedBy: context.requestedBy,\n        queryType: context.queryType,\n      });\n\n    return new SearchResult(this.player, {\n      query: context.query,\n      tracks: [result.data],\n      playlist: null,\n      queryType: context.queryType,\n      requestedBy: context.requestedBy,\n    });\n  }\n}\n\nexport class DiscordPlayerQueryResultCache<T = unknown> {\n  public expireAfter = DEFAULT_EXPIRY_TIMEOUT;\n  public constructor(public data: T, expireAfter: number = DEFAULT_EXPIRY_TIMEOUT) {\n    if (typeof expireAfter === 'number') {\n      this.expireAfter = Date.now() + expireAfter;\n    }\n  }\n\n  public hasExpired() {\n    if (typeof this.expireAfter !== 'number' || isNaN(this.expireAfter) || this.expireAfter < 1) return false;\n    return Date.now() <= this.expireAfter;\n  }\n}\n\nexport interface QueryCacheResolverContext {\n  query: string;\n  requestedBy?: User;\n  queryType?: SearchQueryType | `ext:${string}`;\n}\n", "import { FFmpeg } from '@discord-player/ffmpeg';\nimport {\n  Client,\n  SnowflakeUtil,\n  VoiceState,\n  IntentsBitField,\n  User,\n  GuildVoiceChannelResolvable,\n  version as djsVersion,\n  Events,\n} from 'discord.js';\nimport { Playlist, Track, SearchResult } from './fabric';\nimport {\n  GuildQueueEvents,\n  VoiceConnectConfig,\n  GuildNodeCreateOptions,\n  GuildNodeManager,\n  GuildQueue,\n  ResourcePlayOptions,\n  GuildQueueEvent,\n} from './queue';\nimport { VoiceUtils } from './VoiceInterface/VoiceUtils';\nimport {\n  PlayerEvents,\n  QueryType,\n  SearchOptions,\n  PlayerInitOptions,\n  PlaylistInitData,\n  SearchQueryType,\n  PlayerEvent,\n} from './types/types';\nimport { QueryResolver, ResolvedQuery } from './utils/QueryResolver';\nimport { Util } from './utils/Util';\nimport { version as dVoiceVersion } from 'discord-voip';\nimport { ExtractorExecutionContext } from './extractors/ExtractorExecutionContext';\nimport { BaseExtractor } from './extractors/BaseExtractor';\nimport { QueryCache } from './utils/QueryCache';\nimport { PlayerEventsEmitter } from './utils/PlayerEventsEmitter';\nimport { Exceptions } from './errors';\nimport { defaultVoiceStateHandler } from './DefaultVoiceStateHandler';\nimport { Context, createContext } from './hooks';\nimport { HooksCtx, SUPER_CONTEXT } from './hooks/common';\nimport { LrcLib } from './lrclib/LrcLib';\nimport { getCompatName, isClientProxy } from './compat/createErisCompat';\nimport { DependencyReportGenerator } from './utils/DependencyReportGenerator';\nimport { getGlobalRegistry } from './utils/__internal__';\n\nexport interface PlayerNodeInitializationResult<T = unknown> {\n  track: Track;\n  extractor: BaseExtractor | null;\n  searchResult: SearchResult;\n  queue: GuildQueue<T>;\n}\n\nexport type TrackLike = string | Track | SearchResult | Track[] | Playlist;\n\nexport interface PlayerNodeInitializerOptions<T> extends SearchOptions {\n  nodeOptions?: GuildNodeCreateOptions<T>;\n  connectionOptions?: VoiceConnectConfig;\n  audioPlayerOptions?: ResourcePlayOptions;\n  signal?: AbortSignal;\n  afterSearch?: (result: SearchResult) => Promise<SearchResult>;\n}\n\nexport type VoiceStateHandler = (\n  player: Player,\n  queue: GuildQueue,\n  oldVoiceState: VoiceState,\n  newVoiceState: VoiceState,\n) => Awaited<void>;\n\nexport class Player extends PlayerEventsEmitter<PlayerEvents> {\n  #lastLatency = -1;\n  #voiceStateUpdateListener = this.handleVoiceState.bind(this);\n  #lagMonitorTimeout!: NodeJS.Timeout;\n  #lagMonitorInterval!: NodeJS.Timeout;\n  #onVoiceStateUpdate: VoiceStateHandler = defaultVoiceStateHandler;\n  #hooksCtx: Context<HooksCtx> | null = null;\n  /**\n   * The version of discord-player\n   */\n  public static readonly version: string = '7.0.0-dev.5';\n  /**\n   * The unique identifier of this player instance\n   */\n  public readonly id = SnowflakeUtil.generate().toString();\n  /**\n   * The discord.js client\n   */\n  public readonly client!: Client;\n  /**\n   * The player options\n   */\n  public readonly options!: PlayerInitOptions;\n  /**\n   * The player nodes (queue) manager\n   */\n  public nodes = new GuildNodeManager(this);\n  /**\n   * The voice api utilities\n   */\n  public readonly voiceUtils = new VoiceUtils(this);\n  /**\n   * The extractors manager\n   */\n  public extractors = new ExtractorExecutionContext(this);\n  /**\n   * The player events channel\n   */\n  public events = new PlayerEventsEmitter<GuildQueueEvents>([GuildQueueEvent.Error, GuildQueueEvent.PlayerError]);\n  /**\n   * The player version\n   */\n  public readonly version = Player.version;\n  /**\n   * The lyrics api\n   */\n  public readonly lyrics = new LrcLib(this);\n\n  /**\n   * Creates new Discord Player\n   * @param {Client} client The Discord Client\n   * @param {PlayerInitOptions} [options] The player init options\n   */\n  public constructor(client: Client, options: PlayerInitOptions = {}) {\n    super([PlayerEvent.Error]);\n\n    if (options.ffmpegPath) {\n      if (typeof options.ffmpegPath !== 'string')\n        throw new TypeError(`Expected type \"string\" for options.ffmpegPath. Got ${typeof options.ffmpegPath} instead`);\n\n      process.env.FFMPEG_PATH = options.ffmpegPath;\n    }\n\n    const isCompatMode = isClientProxy(client);\n\n    /**\n     * The discord client\n     * @type {Client}\n     */\n    this.client = client;\n\n    if (!isCompatMode) {\n      try {\n        if (!(client instanceof Client)) {\n          Util.warn(\n            `Client is not an instance of discord.js@${djsVersion} client, some things may not work correctly. This can happen due to corrupt dependencies or having multiple installations of discord.js.`,\n            'InvalidClientInstance',\n          );\n        }\n\n        const ibf =\n          this.client.options.intents instanceof IntentsBitField\n            ? this.client.options.intents\n            : new IntentsBitField(this.client.options.intents);\n\n        if (!ibf.has(IntentsBitField.Flags.GuildVoiceStates)) {\n          Util.warn('client is missing \"GuildVoiceStates\" intent', 'InvalidIntentsBitField');\n        }\n      } catch {\n        // noop\n      }\n    }\n\n    this.options = {\n      lockVoiceStateHandler: false,\n      blockExtractors: [],\n      blockStreamFrom: [],\n      connectionTimeout: 20000,\n      lagMonitor: 30000,\n      queryCache: options.queryCache === null ? null : options.queryCache || new QueryCache(this),\n      useLegacyFFmpeg: false,\n      skipFFmpeg: true,\n      probeTimeout: 5000,\n      overrideFallbackContext: true,\n      ...options,\n    } as PlayerInitOptions;\n\n    if (!isCompatMode) {\n      // @ts-ignore private method\n      this.client.incrementMaxListeners();\n      this.client.on(Events.VoiceStateUpdate, this.#voiceStateUpdateListener);\n    } else {\n      try {\n        // @ts-ignore private method\n        this.client.__dp_voiceStateUpdate_proxy(this.#voiceStateUpdateListener);\n      } catch (e) {\n        Util.warn(\n          'Failed to attach voice state update proxy, voice state handler will not work properly',\n          'CompatModeError',\n        );\n      }\n    }\n\n    if (typeof this.options.lagMonitor === 'number' && this.options.lagMonitor > 0) {\n      this.#lagMonitorInterval = setInterval(() => {\n        const start = performance.now();\n        this.#lagMonitorTimeout = setTimeout(() => {\n          this.#lastLatency = performance.now() - start;\n          if (this.hasDebugger) this.debug(`[Lag Monitor] Event loop latency: ${this.#lastLatency}ms`);\n        }, 0).unref();\n      }, this.options.lagMonitor).unref();\n    }\n\n    if (this.options.overrideFallbackContext) {\n      getGlobalRegistry().set('@[player]', this);\n    }\n  }\n\n  /**\n   * The hooks context for this player instance.\n   */\n  public get context() {\n    if (!this.#hooksCtx) {\n      this.#hooksCtx = createContext();\n\n      const originalProvider = this.#hooksCtx.provide.bind(this.#hooksCtx);\n\n      this.#hooksCtx.provide = (value, receiver) => {\n        return SUPER_CONTEXT.provide(this, () => {\n          return originalProvider(value, () => {\n            return receiver();\n          });\n        });\n      };\n    }\n\n    return this.#hooksCtx;\n  }\n\n  /**\n   * Override default voice state update handler\n   * @param handler The handler callback\n   */\n  public onVoiceStateUpdate(handler: VoiceStateHandler) {\n    this.#onVoiceStateUpdate = handler;\n  }\n\n  public debug(m: string) {\n    return this.emit('debug', m);\n  }\n\n  /**\n   * Creates new discord-player instance.\n   * @param client The client that instantiated player\n   * @param options Player initializer options\n   */\n  public static create(client: Client, options: PlayerInitOptions = {}) {\n    return new Player(client, options);\n  }\n\n  /**\n   * The current query cache provider in use\n   */\n  public get queryCache() {\n    return this.options.queryCache ?? null;\n  }\n\n  /**\n   * Alias to `Player.nodes`.\n   */\n  public get queues() {\n    return this.nodes;\n  }\n\n  /**\n   * Event loop latency in ms. If your bot is laggy and this returns a number above 20ms for example,\n   * some expensive task is being executed on the current thread which is slowing down the event loop.\n   * @type {number}\n   */\n  public get eventLoopLag() {\n    return this.#lastLatency;\n  }\n\n  /**\n   * Generates statistics that could be useful. Statistics generator is still experimental.\n   * @example ```typescript\n   * const stats = player.generateStatistics();\n   *\n   * console.log(stats);\n   *\n   * // outputs something like\n   * // {\n   * //   queuesCount: number,\n   * //   queryCacheEnabled: boolean,\n   * //   queues: [\n   * //      GuildQueueStatisticsMetadata,\n   * //      GuildQueueStatisticsMetadata,\n   * //      GuildQueueStatisticsMetadata,\n   * //      ...\n   * //   ]\n   * // }\n   * ```\n   */\n  public generateStatistics() {\n    return {\n      queuesCount: this.queues.cache.size,\n      queryCacheEnabled: this.queryCache != null,\n      queues: this.queues.cache.map((m) => m.stats.generate()),\n    };\n  }\n\n  /**\n   * Whether the player is in compatibility mode. Compatibility mode is enabled when non-discord.js client is used.\n   */\n  public isCompatMode() {\n    return isClientProxy(this.client);\n  }\n\n  /**\n   * Destroy every single queues managed by this master player instance\n   * @example ```typescript\n   * // use me when you want to immediately terminate every single queues in existence \uD83D\uDD2A\n   * await player.destroy();\n   * ```\n   */\n  public async destroy() {\n    this.nodes.cache.forEach((node) => node.delete());\n\n    if (!this.isCompatMode()) {\n      this.client.off(Events.VoiceStateUpdate, this.#voiceStateUpdateListener);\n      // @ts-ignore private method\n      this.client.decrementMaxListeners();\n    }\n\n    this.removeAllListeners();\n    this.events.removeAllListeners();\n    await this.extractors.unregisterAll();\n    if (this.#lagMonitorInterval) clearInterval(this.#lagMonitorInterval);\n    if (this.#lagMonitorTimeout) clearInterval(this.#lagMonitorTimeout);\n  }\n\n  private _handleVoiceState(oldState: VoiceState, newState: VoiceState) {\n    const queue = this.nodes.get(oldState.guild.id);\n    if (!queue || !queue.connection || !queue.channel) return;\n\n    // dispatch voice state update\n    const wasHandled = this.events.emit(GuildQueueEvent.VoiceStateUpdate, queue, oldState, newState);\n    // if the event was handled, return assuming the listener implemented all of the logic below\n    if (wasHandled && !this.options.lockVoiceStateHandler) return;\n\n    return this.#onVoiceStateUpdate(this, queue, oldState, newState);\n  }\n\n  /**\n   * Handles voice state update\n   * @param {VoiceState} oldState The old voice state\n   * @param {VoiceState} newState The new voice state\n   * @returns {void}\n   * @example ```typescript\n   * // passing voice state update data to this method will trigger voice state handler\n   *\n   * client.on('voiceStateUpdate', (oldState, newState) => {\n   *   // this is definitely a rocket science, right here\n   *   player.handleVoiceState(oldState, newState);\n   * });\n   * ```\n   */\n  public handleVoiceState(oldState: VoiceState, newState: VoiceState): void {\n    this._handleVoiceState(oldState, newState);\n  }\n\n  /**\n   * Lock voice state handler. When this method is called, discord-player will keep using the default voice state update handler, even if custom implementation exists.\n   */\n  public lockVoiceStateHandler() {\n    this.options.lockVoiceStateHandler = true;\n  }\n\n  /**\n   * Unlock voice state handler. When this method is called, discord-player will stop using the default voice state update handler if custom implementation exists.\n   */\n  public unlockVoiceStateHandler() {\n    this.options.lockVoiceStateHandler = false;\n  }\n\n  /**\n   * Checks if voice state handler is locked.\n   */\n  public isVoiceStateHandlerLocked() {\n    return !!this.options.lockVoiceStateHandler;\n  }\n\n  /**\n   * Initiate audio player\n   * @param channel The voice channel on which the music should be played\n   * @param query The track or source to play\n   * @param options Options for player\n   * @example ```typescript\n   * // no need to worry about queue management, just use this method \uD83D\uDE04\n   * const query = 'this is my super cool search query that I want to play';\n   *\n   * try {\n   *    const { track } = await player.play(voiceChannel, query);\n   *   console.log(`\uD83C\uDF89 I am playing ${track.title} \uD83C\uDF89`);\n   * } catch(e) {\n   *   console.log(`\uD83D\uDE2D Failed to play error oh no:\\n\\n${e}`);\n   * }\n   * ```\n   */\n  public async play<T = unknown>(\n    channel: GuildVoiceChannelResolvable,\n    query: TrackLike,\n    options: PlayerNodeInitializerOptions<T> = {},\n  ): Promise<PlayerNodeInitializationResult<T>> {\n    const vc = this.client.channels.resolve(channel);\n    if (!vc?.isVoiceBased())\n      throw Exceptions.ERR_INVALID_ARG_TYPE(\n        'channel',\n        'VoiceBasedChannel',\n        !vc ? 'undefined' : `channel type ${vc.type}`,\n      );\n\n    const originalResult = query instanceof SearchResult ? query : await this.search(query, options);\n    const result = (await options.afterSearch?.(originalResult)) || originalResult;\n    if (result.isEmpty()) {\n      throw Exceptions.ERR_NO_RESULT(\n        `No results found for \"${query}\" (Extractor: ${result.extractor?.identifier || 'N/A'})`,\n      );\n    }\n\n    const queue = this.nodes.create(vc.guild, options.nodeOptions);\n\n    if (this.hasDebugger) this.debug(`[AsyncQueue] Acquiring an entry...`);\n    const entry = queue.tasksQueue.acquire({ signal: options.signal });\n    if (this.hasDebugger) this.debug(`[AsyncQueue] Entry ${entry.id} was acquired successfully!`);\n\n    if (this.hasDebugger) this.debug(`[AsyncQueue] Waiting for the queue to resolve...`);\n    await entry.getTask();\n    if (this.hasDebugger) this.debug(`[AsyncQueue] Entry ${entry.id} was resolved!`);\n\n    try {\n      if (!queue.channel) await queue.connect(vc, options.connectionOptions);\n\n      if (!result.playlist) {\n        queue.addTrack(result.tracks[0]);\n      } else {\n        queue.addTrack(result.playlist);\n      }\n      if (!queue.isPlaying()) await queue.node.play(null, options.audioPlayerOptions);\n    } finally {\n      if (this.hasDebugger) this.debug(`[AsyncQueue] Releasing an entry from the queue...`);\n      queue.tasksQueue.release();\n    }\n\n    return {\n      track: result.tracks[0],\n      extractor: result.extractor,\n      searchResult: result,\n      queue,\n    };\n  }\n\n  /**\n   * Search tracks\n   * @param {string | Track | Track[] | Playlist | SearchResult} query The search query\n   * @param {SearchOptions} options The search options\n   * @returns {Promise<SearchResult>}\n   * @example ```typescript\n   * const searchQuery = 'pass url or text or discord-player track constructable objects, we got you covered \uD83D\uDE0E';\n   * const result = await player.search(searchQuery);\n   *\n   * console.log(result); // Logs `SearchResult` object\n   * ```\n   */\n  public async search(\n    searchQuery: string | Track | Track[] | Playlist | SearchResult,\n    options: SearchOptions = {},\n  ): Promise<SearchResult> {\n    if (searchQuery instanceof SearchResult) return searchQuery;\n\n    if (options.requestedBy != null) options.requestedBy = this.client.users.resolve(options.requestedBy)!;\n    options.blockExtractors ??= this.options.blockExtractors;\n    options.fallbackSearchEngine ??= QueryType.AUTO_SEARCH;\n\n    if (searchQuery instanceof Track) {\n      return new SearchResult(this, {\n        playlist: searchQuery.playlist || null,\n        tracks: [searchQuery],\n        query: searchQuery.title,\n        extractor: searchQuery.extractor,\n        queryType: searchQuery.queryType,\n        requestedBy: options.requestedBy,\n      });\n    }\n\n    if (searchQuery instanceof Playlist) {\n      return new SearchResult(this, {\n        playlist: searchQuery,\n        tracks: searchQuery.tracks,\n        query: searchQuery.title,\n        extractor: searchQuery.tracks[0]?.extractor,\n        queryType: QueryType.AUTO,\n        requestedBy: options.requestedBy,\n      });\n    }\n\n    if (Array.isArray(searchQuery)) {\n      const tracks = searchQuery.filter((t) => t instanceof Track);\n      return new SearchResult(this, {\n        playlist: null,\n        tracks,\n        query: '@@#%{{UserLoadedContent}}%#@@',\n        extractor: null,\n        queryType: QueryType.AUTO,\n        requestedBy: options.requestedBy,\n      });\n    }\n\n    if (this.hasDebugger) this.debug(`Searching ${searchQuery}`);\n\n    let extractor: BaseExtractor | null = null,\n      protocol: string | null = null;\n\n    options.searchEngine ??= QueryType.AUTO;\n    options.fallbackSearchEngine ??= QueryType.AUTO_SEARCH;\n\n    if (this.hasDebugger)\n      this.debug(\n        `Search engine set to ${options.searchEngine}, fallback search engine set to ${options.fallbackSearchEngine}`,\n      );\n\n    if (/^\\w+:/.test(searchQuery)) {\n      const [protocolName, ...query] = searchQuery.split(':');\n      if (this.hasDebugger) this.debug(`Protocol ${protocolName} detected in query`);\n\n      const matchingExtractor = this.extractors.store.find(\n        (e) => !this.extractors.isDisabled(e.identifier) && e.protocols.includes(protocolName),\n      );\n\n      if (matchingExtractor) {\n        if (this.hasDebugger)\n          this.debug(`Protocol ${protocolName} is supported by ${matchingExtractor.identifier} extractor!`);\n        extractor = matchingExtractor;\n        searchQuery = query.join(':');\n        protocol = protocolName;\n      } else {\n        if (this.hasDebugger)\n          this.debug(\n            `Could not find an extractor that supports ${protocolName} protocol. Falling back to default behavior...`,\n          );\n      }\n    }\n\n    const redirected = await QueryResolver.preResolve(searchQuery);\n    const { type: queryType, query } =\n      options.searchEngine === QueryType.AUTO\n        ? QueryResolver.resolve(redirected, options.fallbackSearchEngine)\n        : ({ type: options.searchEngine, query: redirected } as ResolvedQuery);\n\n    if (this.hasDebugger)\n      this.debug(\n        `Query type identified as ${queryType}${\n          extractor && protocol ? ' but might not be used due to the presence of protocol' : ''\n        }`,\n      );\n\n    // force particular extractor\n    if (options.searchEngine.startsWith('ext:')) {\n      if (this.hasDebugger) this.debug(`Forcing ${options.searchEngine.substring(4)} extractor...`);\n      extractor = this.extractors.get(options.searchEngine.substring(4))!;\n      if (!extractor)\n        return new SearchResult(this, {\n          query,\n          queryType,\n          extractor,\n          requestedBy: options.requestedBy,\n        });\n    }\n\n    // query all extractors\n    if (!extractor) {\n      // cache validation\n      if (!options.ignoreCache) {\n        if (this.hasDebugger) this.debug(`Checking cache...`);\n        const res = await this.queryCache?.resolve({\n          query,\n          queryType,\n          requestedBy: options.requestedBy,\n        });\n        // cache hit\n        if (res?.hasTracks()) {\n          if (this.hasDebugger) this.debug(`Cache hit for query ${query}`);\n          return res;\n        }\n\n        if (this.hasDebugger) this.debug(`Cache miss for query ${query}`);\n      }\n\n      if (this.hasDebugger) this.debug(`Executing extractors...`);\n\n      // cache miss\n      extractor =\n        (\n          await this.extractors.run(async (ext) => {\n            if (options.blockExtractors?.includes(ext.identifier)) return false;\n            return ext.validate(query, queryType as SearchQueryType);\n          })\n        )?.extractor || null;\n    }\n\n    // no extractors available\n    if (!extractor) {\n      if (this.hasDebugger) this.debug('Failed to find appropriate extractor');\n      return new SearchResult(this, {\n        query,\n        queryType,\n        requestedBy: options.requestedBy,\n      });\n    }\n\n    if (this.hasDebugger) this.debug(`Executing metadata query using ${extractor.identifier} extractor...`);\n    const res = await extractor\n      .handle(query, {\n        type: queryType as SearchQueryType,\n        requestedBy: options.requestedBy as User,\n        requestOptions: options.requestOptions,\n        protocol,\n      })\n      .catch(() => null);\n\n    if (res) {\n      if (this.hasDebugger) this.debug('Metadata query was successful!');\n      const result = new SearchResult(this, {\n        query,\n        queryType,\n        playlist: res.playlist,\n        tracks: res.tracks,\n        extractor,\n        requestedBy: options.requestedBy,\n      });\n\n      if (!options.ignoreCache) {\n        if (this.hasDebugger) this.debug(`Adding data to cache...`);\n        await this.queryCache?.addData(result);\n      }\n\n      return result;\n    }\n\n    if (this.hasDebugger) this.debug('Failed to find result using appropriate extractor. Querying all extractors...');\n    const result = await this.extractors.run(\n      async (ext) =>\n        !options.blockExtractors?.includes(ext.identifier) &&\n        (await ext.validate(query)) &&\n        ext.handle(query, {\n          type: queryType as SearchQueryType,\n          requestedBy: options.requestedBy as User,\n          requestOptions: options.requestOptions,\n          protocol,\n        }),\n    );\n    if (!result?.result) {\n      if (this.hasDebugger)\n        this.debug(`Failed to query metadata query using ${result?.extractor.identifier || 'N/A'} extractor.`);\n      return new SearchResult(this, {\n        query,\n        queryType,\n        requestedBy: options.requestedBy,\n        extractor: result?.extractor,\n      });\n    }\n\n    if (this.hasDebugger) this.debug(`Metadata query was successful using ${result.extractor.identifier}!`);\n\n    const data = new SearchResult(this, {\n      query,\n      queryType,\n      playlist: result.result.playlist,\n      tracks: result.result.tracks,\n      extractor: result.extractor,\n      requestedBy: options.requestedBy,\n    });\n\n    if (!options.ignoreCache) {\n      if (this.hasDebugger) this.debug(`Adding data to cache...`);\n      await this.queryCache?.addData(data);\n    }\n\n    return data;\n  }\n\n  /**\n   * Generates a report of the dependencies used by the `discord-voip` module. Useful for debugging.\n   * @example ```typescript\n   * console.log(player.scanDeps());\n   * // -> logs dependencies report\n   * ```\n   * @returns {string}\n   */\n  public scanDeps() {\n    const line = '-'.repeat(50);\n    const runtime = 'Bun' in globalThis ? 'Bun' : 'Deno' in globalThis ? 'Deno' : 'Node';\n    const depsReport = [\n      'Discord Player',\n      line,\n      `- discord-player: ${Player.version}${\n        this.isCompatMode() ? ` (${getCompatName(this.client)} compatibility mode)` : ''\n      }`,\n      `- discord-voip: ${dVoiceVersion}`,\n      `- discord.js: ${djsVersion}`,\n      `- Node version: ${process.version} (Detected Runtime: ${runtime}, Platform: ${process.platform} [${process.arch}])`,\n      (() => {\n        if (this.options.useLegacyFFmpeg) return '- ffmpeg: N/A (using legacy ffmpeg)';\n        const info = FFmpeg.resolveSafe();\n        if (!info) return 'FFmpeg/Avconv not found';\n\n        return [\n          `- ffmpeg: ${info.version}`,\n          `- command: ${info.command}`,\n          `- static: ${info.module}`,\n          `- libopus: ${info.result!.includes('--enable-libopus')}`,\n        ].join('\\n');\n      })(),\n      '\\n',\n      'Loaded Extractors:',\n      line,\n      this.extractors.store\n        .map((m) => {\n          return m.identifier;\n        })\n        .join('\\n') || 'N/A',\n      '\\n\\ndiscord-voip',\n      DependencyReportGenerator.generateString(),\n    ];\n\n    return depsReport.join('\\n');\n  }\n\n  public *[Symbol.iterator]() {\n    yield* this.nodes.cache.values();\n  }\n\n  /**\n   * Creates `Playlist` instance\n   * @param data The data to initialize a playlist\n   */\n  public createPlaylist(data: PlaylistInitData) {\n    return new Playlist(this, data);\n  }\n}\n", "import { ChannelType, VoiceState } from 'discord.js';\nimport { GuildQueue, GuildQueueEvent } from './queue';\nimport { Player } from './Player';\nimport { Util } from './utils/Util';\n\nexport async function defaultVoiceStateHandler(\n  player: Player,\n  queue: GuildQueue,\n  oldState: VoiceState,\n  newState: VoiceState,\n) {\n  if (!queue || !queue.connection || !queue.channel) return;\n\n  if (oldState.channelId && !newState.channelId && newState.member?.id === newState.guild.members.me?.id) {\n    try {\n      queue.delete();\n    } catch {\n      /* noop */\n    }\n    return void player.events.emit(GuildQueueEvent.Disconnect, queue);\n  }\n\n  if (queue.options.pauseOnEmpty) {\n    const isEmpty = Util.isVoiceEmpty(queue.channel);\n\n    if (isEmpty) {\n      queue.node.setPaused(true);\n      Reflect.set(queue, '__pausedOnEmpty', true);\n      if (queue.hasDebugger) {\n        queue.debug('Voice channel is empty and options#pauseOnEmpty is true, pausing...');\n      }\n    } else {\n      if (Reflect.get(queue, '__pausedOnEmpty')) {\n        queue.node.setPaused(false);\n        Reflect.set(queue, '__pausedOnEmpty', false);\n        if (queue.hasDebugger) {\n          queue.debug('Voice channel is not empty and options#pauseOnEmpty is true, resuming...');\n        }\n      }\n    }\n  }\n\n  if (!oldState.channelId && newState.channelId && newState.member?.id === newState.guild.members.me?.id) {\n    if (newState.serverMute != null && oldState.serverMute !== newState.serverMute) {\n      queue.node.setPaused(newState.serverMute);\n    } else if (\n      newState.channel?.type === ChannelType.GuildStageVoice &&\n      newState.suppress != null &&\n      oldState.suppress !== newState.suppress\n    ) {\n      queue.node.setPaused(newState.suppress);\n      if (newState.suppress) {\n        newState.guild.members.me?.voice.setRequestToSpeak(true).catch(Util.noop);\n      }\n    }\n  }\n\n  if (!newState.channelId && oldState.channelId === queue.channel.id) {\n    if (!Util.isVoiceEmpty(queue.channel)) return;\n    const timeout = setTimeout(() => {\n      if (!Util.isVoiceEmpty(queue.channel!)) return;\n      if (!player.nodes.has(queue.guild.id)) return;\n      if (queue.options.leaveOnEmpty) queue.delete();\n      player.events.emit(GuildQueueEvent.EmptyChannel, queue);\n    }, queue.options.leaveOnEmptyCooldown || 0).unref();\n    queue.timeouts.set(`empty_${oldState.guild.id}`, timeout);\n  }\n\n  if (newState.channelId && newState.channelId === queue.channel.id) {\n    const emptyTimeout = queue.timeouts.get(`empty_${oldState.guild.id}`);\n    const channelEmpty = Util.isVoiceEmpty(queue.channel);\n    if (!channelEmpty && emptyTimeout) {\n      clearTimeout(emptyTimeout);\n      queue.timeouts.delete(`empty_${oldState.guild.id}`);\n      player.events.emit(GuildQueueEvent.ChannelPopulate, queue);\n    }\n  }\n\n  if (oldState.channelId && newState.channelId && oldState.channelId !== newState.channelId) {\n    if (newState.member?.id === newState.guild.members.me?.id) {\n      if (queue.connection && newState.member?.id === newState.guild.members.me?.id) queue.channel = newState.channel!;\n      const emptyTimeout = queue.timeouts.get(`empty_${oldState.guild.id}`);\n      const channelEmpty = Util.isVoiceEmpty(queue.channel);\n      if (!channelEmpty && emptyTimeout) {\n        clearTimeout(emptyTimeout);\n        queue.timeouts.delete(`empty_${oldState.guild.id}`);\n        player.events.emit(GuildQueueEvent.ChannelPopulate, queue);\n      } else {\n        const timeout = setTimeout(() => {\n          if (queue.connection && !Util.isVoiceEmpty(queue.channel!)) return;\n          if (!player.nodes.has(queue.guild.id)) return;\n          if (queue.options.leaveOnEmpty) queue.delete();\n          player.events.emit(GuildQueueEvent.EmptyChannel, queue);\n        }, queue.options.leaveOnEmptyCooldown || 0).unref();\n        queue.timeouts.set(`empty_${oldState.guild.id}`, timeout);\n      }\n    } else {\n      if (newState.channelId !== queue.channel.id) {\n        const channelEmpty = Util.isVoiceEmpty(queue.channel!);\n        if (!channelEmpty) return;\n        if (queue.timeouts.has(`empty_${oldState.guild.id}`)) return;\n        const timeout = setTimeout(() => {\n          if (!Util.isVoiceEmpty(queue.channel!)) return;\n          if (!player.nodes.has(queue.guild.id)) return;\n          if (queue.options.leaveOnEmpty) queue.delete();\n          player.events.emit(GuildQueueEvent.EmptyChannel, queue);\n        }, queue.options.leaveOnEmptyCooldown || 0).unref();\n        queue.timeouts.set(`empty_${oldState.guild.id}`, timeout);\n      } else {\n        const emptyTimeout = queue.timeouts.get(`empty_${oldState.guild.id}`);\n        const channelEmpty = Util.isVoiceEmpty(queue.channel!);\n        if (!channelEmpty && emptyTimeout) {\n          clearTimeout(emptyTimeout);\n          queue.timeouts.delete(`empty_${oldState.guild.id}`);\n          player.events.emit(GuildQueueEvent.ChannelPopulate, queue);\n        }\n      }\n    }\n  }\n}\n", "import { resolve, dirname } from 'node:path';\nimport { FFmpeg, FFmpegLib } from '@discord-player/ffmpeg';\n\nexport interface PackageJSON {\n  name: string;\n  version: string;\n}\n\nexport type MaybeNull<T> = T | null;\n\nexport interface DependenciesReport {\n  core: {\n    'discord-player': string;\n    'discord-voip': string;\n  };\n  libopus: {\n    mediaplex: MaybeNull<string>;\n    '@discordjs/opus': MaybeNull<string>;\n    '@evan/opus': MaybeNull<string>;\n    opusscript: MaybeNull<string>;\n    'node-opus': MaybeNull<string>;\n  };\n  libsodium: {\n    'sodium-native': MaybeNull<string>;\n    sodium: MaybeNull<string>;\n    'libsodium-wrappers': MaybeNull<string>;\n    'sodium-javascript': MaybeNull<string>;\n    '@stablelib/xchacha20poly1305': MaybeNull<string>;\n    '@nobel/ciphers': MaybeNull<string>;\n  };\n  ffmpeg: FFmpegReport;\n}\n\nexport type FFmpegReport = Record<\n  FFmpegLib,\n  MaybeNull<{\n    version: string;\n    hasLibopus: boolean;\n  }>\n>;\n\n/**\n * A utility to generate a report of the dependencies used by the discord-player module.\n */\nexport const DependencyReportGenerator = {\n  /**\n   * Finds the package.json file of a package.\n   * @param dir - The directory to start searching from\n   * @param packageName - The name of the package to find\n   * @param depth - The maximum depth to search\n   * @returns The package.json file, or null if not found\n   */\n  findPackageJSON(dir: string, packageName: string, depth: number): PackageJSON | null {\n    if (depth === 0) return null;\n\n    const target = resolve(dir, 'package.json');\n\n    const next = () => DependencyReportGenerator.findPackageJSON(resolve(dir, '..'), packageName, depth - 1);\n\n    try {\n      // eslint-disable-next-line @typescript-eslint/no-var-requires\n      const pkgJSON: PackageJSON = require(target);\n\n      if (pkgJSON.name !== packageName) {\n        return next();\n      }\n\n      return pkgJSON;\n    } catch {\n      return next();\n    }\n  },\n  /**\n   * Tries to find the version of a dependency.\n   * @param name - The package to find the version of\n   * @param maxLookupDepth - The maximum depth to search for the package.json file\n   * @returns The version of the package, or null if not found\n   */\n  version(name: string, maxLookupDepth = 3): string | null {\n    try {\n      if (name === 'discord-player') {\n        return '7.0.0-dev.5';\n      }\n\n      const pkg = DependencyReportGenerator.findPackageJSON(dirname(require.resolve(name)), name, maxLookupDepth);\n      return pkg?.version ?? null;\n    } catch {\n      return null;\n    }\n  },\n  /**\n   * Generates a report of the dependencies used by the discord-player module.\n   * @returns The report object\n   */\n  generate(): DependenciesReport {\n    const ffmpegReport = {} as FFmpegReport;\n\n    for (const lib of FFmpeg.sources) {\n      ffmpegReport[lib.name] = null;\n    }\n\n    const ffmpeg = FFmpeg.resolveSafe();\n\n    if (ffmpeg) {\n      ffmpegReport[ffmpeg.name] = {\n        hasLibopus: ffmpeg.command.includes('--enable-libopus'),\n        version: ffmpeg.version,\n      };\n    }\n\n    return {\n      core: {\n        'discord-player': DependencyReportGenerator.version('discord-player') as string,\n        'discord-voip': DependencyReportGenerator.version('discord-voip') as string,\n      },\n      libopus: {\n        mediaplex: DependencyReportGenerator.version('mediaplex'),\n        '@discordjs/opus': DependencyReportGenerator.version('@discordjs/opus'),\n        '@evan/opus': DependencyReportGenerator.version('@evan/opus'),\n        opusscript: DependencyReportGenerator.version('opusscript'),\n        'node-opus': DependencyReportGenerator.version('node-opus'),\n      },\n      libsodium: {\n        'sodium-native': DependencyReportGenerator.version('sodium-native'),\n        sodium: DependencyReportGenerator.version('sodium'),\n        'libsodium-wrappers': DependencyReportGenerator.version('libsodium-wrappers'),\n        '@stablelib/xchacha20poly1305': DependencyReportGenerator.version('@stablelib/xchacha20poly1305'),\n        'sodium-javascript': DependencyReportGenerator.version('sodium-javascript'),\n        '@nobel/ciphers': DependencyReportGenerator.version('@nobel/ciphers'),\n      },\n      ffmpeg: ffmpegReport,\n    };\n  },\n  /**\n   * Generates a string representation of the dependencies report.\n   * @returns The string representation\n   */\n  generateString(): string {\n    const report = DependencyReportGenerator.generate();\n    const line = '-'.repeat(50);\n\n    const output: string[] = [];\n\n    output.push('Dependencies Report');\n    output.push(line);\n\n    const keys = Object.keys(report) as (keyof DependenciesReport)[];\n\n    for (const _key of keys) {\n      const key = _key as keyof DependenciesReport;\n\n      output.push(key);\n\n      const subKeys = Object.keys(report[key]);\n\n      for (const _subKey of subKeys) {\n        const subKey = _subKey as keyof DependenciesReport[typeof key];\n        const value = report[key][subKey] ?? 'N/A';\n\n        output.push(`- ${subKey}: ${typeof value === 'object' ? JSON.stringify(value, null, 2) : value}`);\n      }\n\n      output.push('');\n    }\n\n    output.push(line);\n\n    return output.join('\\n');\n  },\n};\n"],
  "mappings": "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",
  "names": ["GuildQueue", "target", "SerializedType", "QueueRepeatMode", "version", "target", "module", "handler", "import_utils", "import_utils", "handler", "handler", "result", "target", "import_utils", "import_discord", "import_utils", "import_utils", "import_discord_voip", "import_utils", "import_discord_voip", "target", "query", "import_promises", "import_discord", "resolve", "resolve", "waitFor", "import_equalizer", "TrackSkipReason", "target", "resolve", "GuildQueue", "GuildQueue", "import_promises", "version", "import_discord_voip", "import_utils", "import_ffmpeg", "import_discord", "import_discord_voip", "import_discord", "import_ffmpeg", "target", "djsVersion", "handler", "query", "res", "result", "dVoiceVersion", "import_equalizer", "import_discord_voip"]
}

|
|
6198
|
+
//# sourceMappingURL=data:application/json;base64,{
  "version": 3,
  "sources": ["../src/index.ts", "../src/compat/createErisCompat.ts", "../src/utils/Util.ts", "../src/fabric/Track.ts", "../src/errors/index.ts", "../src/utils/TypeUtil.ts", "../src/utils/serde.ts", "../src/fabric/Playlist.ts", "../src/utils/QueryResolver.ts", "../src/fabric/SearchResult.ts", "../src/utils/AudioFilters.ts", "../src/utils/PlayerEventsEmitter.ts", "../src/extractors/BaseExtractor.ts", "../src/extractors/ExtractorExecutionContext.ts", "../src/hooks/context/async-context.ts", "../src/utils/__internal__/_container.ts", "../src/utils/__internal__/getGlobalRegistry.ts", "../src/hooks/common.ts", "../src/hooks/useHistory.ts", "../src/hooks/usePlayer.ts", "../src/hooks/useQueue.ts", "../src/hooks/useMainPlayer.ts", "../src/hooks/useMetadata.ts", "../src/hooks/useTimeline.ts", "../src/hooks/stream/onAfterCreateStream.ts", "../src/hooks/stream/onBeforeCreateStream.ts", "../src/hooks/useVolume.ts", "../src/queue/GuildNodeManager.ts", "../src/queue/GuildQueue.ts", "../src/stream/StreamDispatcher.ts", "../src/queue/GuildQueueHistory.ts", "../src/queue/GuildQueuePlayerNode.ts", "../src/utils/AsyncQueue.ts", "../src/queue/GuildQueueAudioFilters.ts", "../src/utils/FFmpegStream.ts", "../src/queue/GuildQueueStatistics.ts", "../src/queue/SyncedLyricsProvider.ts", "../src/utils/SequentialBucket.ts", "../src/lrclib/LrcLib.ts", "../src/stream/VoiceUtils.ts", "../src/utils/QueryCache.ts", "../src/Player.ts", "../src/DefaultVoiceStateHandler.ts", "../src/utils/DependencyReportGenerator.ts", "../src/version.ts"],
  "sourcesContent": ["export { createErisCompat, isErisProxy } from './compat/createErisCompat';\nexport * from './utils/PlayerEventsEmitter';\nexport * from './utils/AudioFilters';\nexport * from './extractors/BaseExtractor';\nexport * from './extractors/ExtractorExecutionContext';\nexport * from './fabric';\nexport * from './queue';\nexport * from './lrclib/LrcLib';\nexport * from './utils/SequentialBucket';\nexport * from './stream/VoiceUtils';\nexport * from './stream/StreamDispatcher';\nexport * from './utils/Util';\nexport * from './utils/TypeUtil';\nexport * from './utils/AsyncQueue';\nexport * from './utils/FFmpegStream';\nexport * from './utils/QueryCache';\nexport * from './utils/QueryResolver';\nexport * from '@discord-player/ffmpeg';\nexport * from './Player';\nexport * from './hooks';\nexport * from './utils/serde';\nexport * from './utils/DependencyReportGenerator';\nexport {\n  AudioFilters as PCMAudioFilters,\n  type BiquadFilters,\n  FilterType as BiquadFilterType,\n  type PCMFilters,\n  Q_BUTTERWORTH,\n  VolumeTransformer,\n  BASS_EQ_BANDS,\n  AF_NIGHTCORE_RATE,\n  AF_VAPORWAVE_RATE,\n  FiltersChain } from\n'@discord-player/equalizer';\nexport {\n  createAudioPlayer,\n  AudioPlayer,\n  getVoiceConnection,\n  getVoiceConnections,\n  joinVoiceChannel,\n  type JoinConfig,\n  type JoinVoiceChannelOptions,\n  type CreateAudioPlayerOptions } from\n'discord-voip';\n\nexport { version } from './version';", "/* eslint-disable @typescript-eslint/no-explicit-any */\n// @ts-nocheck\n\nimport { ChannelType, GatewayDispatchEvents } from 'discord-api-types/v10';\nimport { Util } from '../utils/Util';\n\nimport type { DiscordGatewayAdapterCreator } from 'discord-voip';\nimport {\n  Client,\n  GatewayVoiceServerUpdateDispatchData,\n  GatewayVoiceStateUpdateDispatchData,\n  VoiceState } from\n'discord.js';\nimport type Eris from 'eris';\n\ntype ErisUserResolvable = Eris.User | string | Eris.Member;\ntype ErisGuildResolvable = Eris.Guild | string | Eris.Member | Eris.GuildChannel | Eris.Role;\ntype ErisChannelResolvable = Eris.GuildChannel | string;\n\nconst DiscordPlayerClientSymbol = Symbol('DiscordPlayerClient');\n\nexport function isClientProxy(client: any): boolean {\n  return Reflect.get(client, DiscordPlayerClientSymbol) != null;\n}\n\nexport function getCompatName(client: any): string {\n  return Reflect.get(client, DiscordPlayerClientSymbol) ?? null;\n}\n\nexport function isErisProxy(client: any): client is Eris.Client {\n  return Reflect.get(client, DiscordPlayerClientSymbol) === 'Eris';\n}\n\nexport function isErisClient(client: any): client is Eris.Client {\n  const { module, error } = Util.require('eris');\n\n  if (error) return false;\n\n  const eris = module as typeof import('eris');\n\n  return client instanceof eris.Client;\n}\n\nfunction declareProperty(target: any, key: string, value: any) {\n  Reflect.set(target, key, value);\n}\n\nfunction getProperty<T>(target: any, key: string): T {\n  return Reflect.get(target, key);\n}\n\n/**\n * Allows Eris clients to be used with discord-player. When this method is called, discord-player creates a proxy object that intercepts certain methods and properties to make it compatible with discord-player.\n * @param client The Eris client to be used.\n * @returns The Eris client with discord-player compatibility.\n */\nexport function createErisCompat(client: Eris.Client): Client {\n  const { module, error } = Util.require('eris');\n\n  if (error) throw error;\n\n  const eris = module as typeof import('eris');\n\n  erisVoiceEventsHandler(client);\n\n  const erisProxy = new Proxy(client, {\n    get(target, p) {\n      switch (p) {\n        case 'users':\n          return erisUsersProxy(target, eris);\n        case 'guilds':\n          return erisGuildsProxy(target, eris);\n        case 'channels':\n          return erisChannelsProxy(target, eris);\n        case '__dp_voiceStateUpdate_proxy':\n          return (handler: (a, b) => void) => erisVoiceStateUpdateProxy(target, erisProxy, handler);\n        case 'incrementMaxListeners':\n          return () => {\n            // @ts-expect-error patching\n            client.setMaxListeners(client.getMaxListeners() + 1);\n          };\n        case 'decrementMaxListeners':\n          return () => {\n            // @ts-expect-error patching\n            const listeners = client.getMaxListeners() - 1;\n\n            // @ts-expect-error patching\n            client.setMaxListeners(listeners < 0 ? 1 : listeners);\n          };\n        default:\n          // @ts-expect-error patching\n          return target[p];\n      }\n    }\n  });\n\n  Reflect.set(erisProxy, DiscordPlayerClientSymbol, 'Eris');\n\n  return erisProxy as unknown as Client;\n}\n\nfunction erisVoiceStateUpdateProxy(client: Eris.Client, proxy: Eris.Client, handler: (a, b) => void) {\n  client.on('voiceStateUpdate', (member, oldState) => {\n    try {\n      const proxiedOldState = {\n        channelId: oldState.channelID,\n        serverMute: oldState.mute,\n        suppress: oldState.suppress,\n        guild: {\n          id: oldState.guild.id\n        },\n        member: {\n          id: oldState.user.id\n        }\n      } as VoiceState;\n\n      const me = member.guild.members.get(client.user.id);\n      const resolvedChannel = member.guild.channels.get(member.voiceState.channelID);\n\n      const proxiedNewState = {\n        channelId: member.voiceState.channelID,\n        serverMute: member.voiceState.mute,\n        suppress: member.voiceState.suppress,\n        channel: erisResolvedChannelProxy(resolvedChannel, client),\n        member: {\n          id: member.id\n        },\n        guild: {\n          id: member.guild.id,\n          members: {\n            me: {\n              id: me?.id,\n              voice: {\n                async setRequestToSpeak(value: boolean) {\n                  void value;\n                  return me?.voiceState;\n                  // if (me) {\n                  //   return me.voice.setRequestToSpeak(value);\n                  // }\n                }\n              }\n            }\n          }\n        }\n      } as VoiceState;\n\n      return handler(proxiedNewState, proxiedOldState);\n    } catch {\n\n      /* noop */}\n  });\n}\n\nfunction erisVoiceEventsHandler(client: Eris.Client) {\n  let adapters = getProperty<Map<string, any>>(client, 'adapters');\n\n  if (!adapters) {\n    const collection = new Map<string, any>();\n    adapters = collection;\n    declareProperty(client, 'adapters', collection);\n  }\n\n  client.on('shardDisconnect', (_, shardId) => {\n    for (const [guildId, adapter] of adapters.entries()) {\n      if (client.guilds.get(guildId)?.shard.id === shardId) {\n        adapter.destroy();\n      }\n    }\n  });\n\n  client.on('rawWS', (packet) => {\n    switch (packet.t) {\n      case GatewayDispatchEvents.VoiceServerUpdate:{\n          const payload = packet.d as GatewayVoiceServerUpdateDispatchData;\n          adapters.get(payload.guild_id)?.onVoiceServerUpdate(payload);\n          return;\n        }\n      case GatewayDispatchEvents.VoiceStateUpdate:{\n          const payload = packet.d as GatewayVoiceStateUpdateDispatchData;\n\n          if (payload.guild_id && payload.session_id && payload.user_id === client.user.id) {\n            adapters.get(payload.guild_id)?.onVoiceStateUpdate(payload);\n          }\n\n          return;\n        }\n      default:\n        break;\n    }\n  });\n}\n\nfunction erisChannelsProxy(client: Eris.Client, eris: typeof import('eris')) {\n  const handler = {\n    client,\n    get cache() {\n      return {\n        get(id: string) {\n          return client.getChannel(id);\n        },\n        has(id: string) {\n          return id in client.channelGuildMap;\n        }\n      };\n    },\n    resolve(resolvable: string | ErisChannelResolvable) {\n      if (typeof resolvable === 'string') {\n        return erisResolvedChannelProxy(this.client.getChannel(resolvable) as Eris.GuildChannel, client);\n      }\n\n      if (resolvable instanceof eris.GuildChannel) {\n        return erisResolvedChannelProxy(resolvable, client);\n      }\n    },\n    resolveId(resolvable: ErisChannelResolvable) {\n      const channel = this.resolve(resolvable);\n      return channel?.id;\n    }\n  };\n\n  return handler;\n}\n\nfunction erisResolvedChannelProxy(\nchannel: Eris.GuildChannel | undefined,\nclient: Eris.Client)\n: Eris.GuildChannel | undefined {\n  if (!channel) return;\n\n  return new Proxy(channel, {\n    get(target, p) {\n      switch (p) {\n        case 'guild':\n          return erisVoiceAdapterProxy(target.guild, client);\n        case 'members':\n          return (target as Eris.VoiceChannel).voiceMembers;\n        case 'isVoiceBased':\n          return () => target.type === ChannelType.GuildVoice || target.type === ChannelType.GuildStageVoice;\n        case 'isVoice':\n          return () => target.type === ChannelType.GuildVoice;\n        case 'isStage':\n          return () => target.type === ChannelType.GuildStageVoice;\n        default:\n          // @ts-expect-error patching\n          return target[p];\n      }\n    }\n  });\n}\n\nfunction erisVoiceAdapterProxy(guild: Eris.Guild | undefined, client: Eris.Client): Eris.Guild | undefined {\n  if (!guild) return;\n\n  return new Proxy(guild, {\n    get(target, p) {\n      if (p === 'voiceAdapterCreator') {\n        return erisVoiceAdapterCreator(target, client);\n      }\n\n      // @ts-expect-error patching\n      return target[p];\n    }\n  });\n}\n\nfunction erisVoiceAdapterCreator(guild: Eris.Guild, client: Eris.Client): DiscordGatewayAdapterCreator {\n  return (methods) => {\n    let adapters = getProperty<Map<string, typeof methods>>(client, 'adapters');\n\n    if (!adapters) {\n      const collection = new Map<string, typeof methods>();\n      adapters = collection;\n      declareProperty(client, 'adapters', collection);\n    }\n\n    adapters.set(guild.id, methods);\n\n    return {\n      sendPayload(payload) {\n        if (guild.shard.status !== 'ready') return false;\n        guild.shard.sendWS(payload.op, payload.d);\n        return true;\n      },\n      destroy() {\n        adapters.delete(guild.id);\n      }\n    };\n  };\n}\n\nfunction erisGuildsProxy(client: Eris.Client, eris: typeof import('eris')) {\n  return new Proxy(client.guilds, {\n    get(target, p) {\n      if (p === 'cache') {\n        return target;\n      }\n\n      if (p === 'resolve' || p === 'resolveId') {\n        const resolver = function (resolvable: ErisGuildResolvable) {\n          if (typeof resolvable === 'string') {\n            return target.get(resolvable);\n          }\n\n          if (resolvable instanceof eris.Guild) {\n            return resolvable;\n          }\n\n          if (\n          resolvable instanceof eris.Member ||\n          resolvable instanceof eris.Guild ||\n          resolvable instanceof eris.GuildChannel ||\n          resolvable instanceof eris.Role)\n          {\n            return resolvable.guild;\n          }\n        };\n\n        if (p === 'resolve') {\n          return resolver;\n        }\n\n        return (resolvable: ErisGuildResolvable) => {\n          const guild = resolver(resolvable);\n          return guild?.id;\n        };\n      }\n\n      // @ts-expect-error patching\n      return target[p];\n    }\n  });\n}\n\nfunction erisUsersProxy(client: Eris.Client, eris: typeof import('eris')) {\n  return new Proxy(client.users, {\n    get(target, p) {\n      if (p === 'cache') {\n        return target;\n      }\n\n      if (p === 'resolve' || p === 'resolveId') {\n        const resolver = function (resolvable: ErisUserResolvable) {\n          if (typeof resolvable === 'string') {\n            return target.get(resolvable);\n          }\n\n          if (resolvable instanceof eris.User) {\n            return resolvable;\n          }\n\n          if (resolvable instanceof eris.Member) {\n            return resolvable.user;\n          }\n        };\n\n        if (p === 'resolve') {\n          return resolver;\n        }\n\n        return (resolvable: ErisUserResolvable) => {\n          const user = resolver(resolvable);\n          return user?.id;\n        };\n      }\n\n      // @ts-expect-error patching\n      return target[p];\n    }\n  });\n}", "import { StageChannel, VoiceChannel } from 'discord.js';\nimport { setTimeout } from 'node:timers/promises';\nimport { GuildQueue } from '../queue';\nimport { Playlist, Track, TrackSource } from '../fabric';\nimport { OutOfSpaceError } from '../errors';\nimport { randomInt } from 'node:crypto';\nimport {\n  createFilter,\n  createSpotifyFilter,\n  fixTrackSuffix,\n  removeLive,\n  removeRemastered,\n  youtube,\n  removeZeroWidth,\n  replaceNbsp,\n  replaceSmartQuotes,\n  removeCleanExplicit } from\n'@web-scrobbler/metadata-filter';\n\nexport type RuntimeType = 'node' | 'deno' | 'bun' | 'unknown';\n\nexport interface TimeData {\n  /**\n   * Time in days\n   */\n  days: number;\n  /**\n   * Time in hours\n   */\n  hours: number;\n  /**\n   * Time in minutes\n   */\n  minutes: number;\n  /**\n   * Time in seconds\n   */\n  seconds: number;\n}\n\nexport interface Runtime {\n  name: RuntimeType;\n  version: string;\n}\n\nclass Util {\n  /**\n   * Utils\n   */\n  private constructor() {} // eslint-disable-line @typescript-eslint/no-empty-function\n\n  /**\n   * Gets the runtime information\n   */\n  static getRuntime(): Runtime {\n    const version = typeof navigator !== 'undefined' ? navigator.userAgent : null;\n\n    // @ts-ignore\n    if (typeof Deno !== 'undefined' && Deno.version) return { name: 'deno', version: Deno.version.deno };\n\n    // @ts-ignore\n    if (typeof Bun !== 'undefined' && Bun.version) return { name: 'bun', version: Bun.version };\n\n    if (typeof process !== 'undefined' && process.version) return { name: 'node', version: process.version };\n\n    return { name: 'unknown', version: version ?? 'unknown' };\n  }\n\n  /**\n   * Creates duration string\n   * @param {object} durObj The duration object\n   * @returns {string}\n   */\n  static durationString(durObj: Record<string, number>) {\n    return Object.values(durObj).\n    map((m) => isNaN(m) ? 0 : m).\n    join(':');\n  }\n\n  /**\n   * Parses milliseconds to consumable time object\n   * @param {number} milliseconds The time in ms\n   * @returns {TimeData}\n   */\n  static parseMS(milliseconds: number) {\n    if (isNaN(milliseconds)) milliseconds = 0;\n    const round = milliseconds > 0 ? Math.floor : Math.ceil;\n\n    return {\n      days: round(milliseconds / 86400000),\n      hours: round(milliseconds / 3600000) % 24,\n      minutes: round(milliseconds / 60000) % 60,\n      seconds: round(milliseconds / 1000) % 60\n    } as TimeData;\n  }\n\n  /**\n   * Builds time code\n   * @param {TimeData} duration The duration object\n   * @returns {string}\n   */\n  static buildTimeCode(duration: TimeData) {\n    const items = Object.keys(duration);\n    const required = ['days', 'hours', 'minutes', 'seconds'];\n\n    const parsed = items.filter((x) => required.includes(x)).map((m) => duration[m as keyof TimeData]);\n    const final = parsed.\n    slice(parsed.findIndex((x) => x !== 0)).\n    map((x) => x.toString().padStart(2, '0')).\n    join(':');\n\n    return final.length <= 3 ? `0:${final.padStart(2, '0') || 0}` : final;\n  }\n\n  /**\n   * Formats duration\n   * @param {number} duration The duration in ms\n   */\n  static formatDuration(duration: number) {\n    return this.buildTimeCode(this.parseMS(duration));\n  }\n\n  /**\n   * Picks last item of the given array\n   * @param {any[]} arr The array\n   * @returns {any}\n   */\n  // eslint-disable-next-line @typescript-eslint/no-explicit-any\n  static last<T = any>(arr: T[]): T {\n    if (!Array.isArray(arr)) return arr;\n    return arr[arr.length - 1];\n  }\n\n  /**\n   * Checks if the voice channel is empty\n   * @param {VoiceChannel|StageChannel} channel The voice channel\n   * @returns {boolean}\n   */\n  static isVoiceEmpty(channel: VoiceChannel | StageChannel) {\n    return channel && channel.members.filter((member) => !member.user.bot).size === 0;\n  }\n\n  /**\n   * Cleans the track title\n   * @param title The title\n   * @param source The source\n   * @returns Cleaned title\n   */\n  static cleanTitle(title: string, source: TrackSource) {\n    try {\n      const filterOpts = {\n        // prettier-ignore\n        track: [\n        removeRemastered,\n        removeLive,\n        fixTrackSuffix,\n        removeZeroWidth,\n        replaceNbsp,\n        replaceSmartQuotes,\n        removeCleanExplicit]\n\n      };\n      const spotifyFilter = createFilter(filterOpts);\n      spotifyFilter.extend(createSpotifyFilter());\n      const defaultFilter = createFilter(filterOpts);\n\n      switch (source) {\n        case 'youtube':\n          return youtube(title);\n        case 'spotify':\n          return spotifyFilter.filterField('track', title);\n        default:\n          return defaultFilter.filterField('track', title);\n      }\n    } catch {\n      return title;\n    }\n  }\n\n  /**\n   * Safer require\n   * @param {string} id Node require id\n   * @returns {any}\n   */\n  static require(id: string) {\n    try {\n      return { module: require(id), error: null };\n    } catch (error) {\n      return { module: null, error };\n    }\n  }\n\n  static async import(id: string) {\n    try {\n      const mod = await import(id);\n      return { module: mod, error: null };\n    } catch (error) {\n      return { module: null, error };\n    }\n  }\n\n  /**\n   * Asynchronous timeout\n   * @param {number} time The time in ms to wait\n   * @returns {Promise<unknown>}\n   */\n  static wait(time: number) {\n    return setTimeout(time, undefined, { ref: false });\n  }\n\n  static noop() {} // eslint-disable-line @typescript-eslint/no-empty-function\n\n  static async getFetch() {\n    if ('fetch' in globalThis) return globalThis.fetch;\n    for (const lib of ['node-fetch', 'undici']) {\n      try {\n        return await import(lib).then((res) => res.fetch || res.default?.fetch || res.default);\n      } catch {\n        try {\n          // eslint-disable-next-line\n          const res = require(lib);\n          if (res) return res.fetch || res.default?.fetch || res.default;\n        } catch {\n\n          // no?\n        }}\n    }\n  }\n\n  static warn(message: string, code = 'DeprecationWarning', detail?: string) {\n    process.emitWarning(message, {\n      code,\n      detail\n    });\n  }\n\n  static randomChoice<T>(src: T[]): T {\n    return src[randomInt(src.length)];\n  }\n\n  static arrayCloneShuffle<T>(src: T[]): T[] {\n    const arr = src.slice();\n\n    let m = arr.length;\n\n    while (m) {\n      const i = Math.floor(Math.random() * m--);\n      [arr[m], arr[i]] = [arr[i], arr[m]];\n    }\n\n    return arr;\n  }\n}\n\nexport const VALIDATE_QUEUE_CAP = (queue: GuildQueue, items: Playlist | Track | Track[]) => {\n  const tracks = items instanceof Playlist ? items.tracks : Array.isArray(items) ? items : [items];\n\n  if (queue.maxSize < 1 || queue.maxSize === Infinity) return;\n\n  const maxCap = queue.getCapacity();\n\n  if (maxCap < tracks.length) {\n    throw new OutOfSpaceError('tracks queue', maxCap, tracks.length);\n  }\n};\n\nexport { Util };", "import { User, escapeMarkdown, SnowflakeUtil, GuildVoiceChannelResolvable, APIUser } from 'discord.js';\nimport { Player, PlayerNodeInitializationResult, PlayerNodeInitializerOptions } from '../Player';\nimport { Playlist, PlaylistJSON } from './Playlist';\nimport { GuildQueue } from '../queue/GuildQueue';\nimport { BaseExtractor } from '../extractors/BaseExtractor';\nimport { Collection } from '@discord-player/utils';\nimport { TypeUtil } from '../utils/TypeUtil';\nimport { SerializedType, tryIntoThumbnailString } from '../utils/serde';\nimport { InvalidArgTypeError } from '../errors';\nimport { Util } from '../utils/Util';\nimport { SearchQueryType } from '../utils/QueryResolver';\nimport { AudioResource } from 'discord-voip';\n\nexport type TrackResolvable = Track | string | number;\n\nexport type WithMetadata<T extends object, M> = T & {\n  metadata: M;\n  requestMetadata(): Promise<M>;\n};\n\nexport type SerializedTrack = ReturnType<Track['serialize']>;\n\n/**\n * The track source:\n * - soundcloud\n * - youtube\n * - spotify\n * - apple_music\n * - arbitrary\n */\nexport type TrackSource = 'soundcloud' | 'youtube' | 'spotify' | 'apple_music' | 'arbitrary';\n\nexport interface RawTrackData {\n  /**\n   * The title\n   */\n  title: string;\n  /**\n   * The description\n   */\n  description: string;\n  /**\n   * The author\n   */\n  author: string;\n  /**\n   * The url\n   */\n  url: string;\n  /**\n   * The thumbnail\n   */\n  thumbnail: string;\n  /**\n   * The duration\n   */\n  duration: string;\n  /**\n   * The duration in ms\n   */\n  views: number;\n  /**\n   * The user who requested this track\n   */\n  requestedBy?: User | null;\n  /**\n   * The playlist\n   */\n  playlist?: Playlist;\n  /**\n   * The source\n   */\n  source?: TrackSource;\n  /**\n   * The engine\n   */\n  engine?: any; // eslint-disable-line @typescript-eslint/no-explicit-any\n  /**\n   * If this track is live\n   */\n  live?: boolean;\n  /**\n   * The raw data\n   */\n  raw?: any; // eslint-disable-line @typescript-eslint/no-explicit-any\n  /**\n   * The query type\n   */\n  queryType?: SearchQueryType;\n  /**\n   * The serialized title\n   */\n  cleanTitle?: string;\n}\n\nexport interface TrackJSON {\n  /**\n   * The track id\n   */\n  id: string;\n  /**\n   * The track title\n   */\n  title: string;\n  /**\n   * The track description\n   */\n  description: string;\n  /**\n   * The track author\n   */\n  author: string;\n  /**\n   * The track url\n   */\n  url: string;\n  /**\n   * The track thumbnail\n   */\n  thumbnail: string;\n  /**\n   * The track duration\n   */\n  duration: string;\n  /**\n   * The track duration in ms\n   */\n  durationMS: number;\n  /**\n   * The track views\n   */\n  views: number;\n  /**\n   * The user id who requested this track\n   */\n  requestedBy: string;\n  /**\n   * The playlist info (if any)\n   */\n  playlist?: PlaylistJSON;\n}\n\nexport class Track<T = unknown> {\n  public title: string;\n  public description: string;\n  public author: string;\n  public url: string;\n  public thumbnail: string;\n  public duration: string;\n  public views: number;\n  public requestedBy: User | null = null;\n  public playlist?: Playlist;\n  public queryType: SearchQueryType | null | undefined = null;\n  // eslint-disable-next-line @typescript-eslint/no-explicit-any\n  public raw: any;\n  public extractor: BaseExtractor | null = null;\n  public readonly id = SnowflakeUtil.generate().toString();\n  private __metadata: T | null = null;\n  private __reqMetadataFn: () => Promise<T | null>;\n  public cleanTitle: string;\n  public live: boolean = false;\n  public bridgedExtractor: BaseExtractor | null = null;\n  public bridgedTrack: Track | null = null;\n\n  #resource: AudioResource<Track> | null = null;\n\n  /**\n   * Track constructor\n   * @param player The player that instantiated this Track\n   * @param data Track data\n   */\n  public constructor(public readonly player: Player, data: Partial<WithMetadata<RawTrackData, T>>) {\n    this.title = escapeMarkdown(data.title ?? '');\n    this.author = data.author ?? '';\n    this.url = data.url ?? '';\n    this.thumbnail = data.thumbnail ?? '';\n    this.duration = data.duration ?? '';\n    this.views = data.views ?? 0;\n    this.queryType = data.queryType;\n    this.requestedBy = data.requestedBy || null;\n    this.playlist = data.playlist;\n    this.description = `${this.title} by ${this.author}`;\n    this.raw = Object.assign({}, { source: data.raw?.source ?? data.source }, data.raw ?? data);\n    this.__metadata = data.metadata ?? null;\n    this.__reqMetadataFn = data.requestMetadata || (() => Promise.resolve<T | null>(null));\n    this.cleanTitle = data.cleanTitle ?? Util.cleanTitle(this.title, this.source);\n    this.live = data.live ?? false;\n  }\n\n  /**\n   * Sets audio resource for this track. This is not useful outside of the library.\n   * @param resource Audio resource\n   */\n  public setResource(resource: AudioResource<Track> | null) {\n    this.#resource = resource;\n  }\n\n  /**\n   * Gets audio resource for this track\n   */\n  public get resource() {\n    return this.#resource;\n  }\n\n  /**\n   * Whether this track has an audio resource\n   */\n  public get hasResource() {\n    return this.#resource != null;\n  }\n\n  /**\n   * Request metadata for this track\n   */\n  public async requestMetadata() {\n    const res = await this.__reqMetadataFn();\n\n    this.setMetadata(res);\n\n    return res;\n  }\n\n  /**\n   * Set metadata for this track\n   */\n  public setMetadata(m: T | null) {\n    this.__metadata = m;\n  }\n\n  /**\n   * Metadata of this track\n   */\n  public get metadata() {\n    return this.__metadata;\n  }\n\n  /**\n   * If this track has metadata\n   */\n  public get hasMetadata() {\n    return this.metadata != null;\n  }\n\n  /**\n   * The queue in which this track is located\n   */\n  public get queue(): GuildQueue {\n    return this.player.nodes.cache.find((q) => q.tracks.some((ab) => ab.id === this.id))!;\n  }\n\n  /**\n   * The track duration in millisecond\n   */\n  public get durationMS(): number {\n    const times = (n: number, t: number) => {\n      let tn = 1;\n      for (let i = 0; i < t; i++) tn *= n;\n      return t <= 0 ? 1000 : tn * 1000;\n    };\n\n    return this.duration.\n    split(':').\n    reverse().\n    map((m, i) => parseInt(m) * times(60, i)).\n    reduce((a, c) => a + c, 0);\n  }\n\n  /**\n   * Discord hyperlink representation of this track\n   */\n  public toHyperlink(): string /* not using `[${string}](${string})` yet */ {\n    return `[${this.title}](${this.url})`;\n  }\n\n  /**\n   * Returns source of this track\n   */\n  public get source() {\n    return this.raw?.source ?? 'arbitrary';\n  }\n\n  /**\n   * String representation of this track\n   */\n  public toString(): string {\n    return `${this.title} by ${this.author}`;\n  }\n\n  /**\n   * Raw JSON representation of this track\n   */\n  public toJSON(hidePlaylist?: boolean) {\n    return {\n      id: this.id,\n      title: this.title,\n      description: this.description,\n      author: this.author,\n      url: this.url,\n      thumbnail: this.thumbnail,\n      duration: this.duration,\n      durationMS: this.durationMS,\n      views: this.views,\n      requestedBy: this.requestedBy?.id || null,\n      playlist: hidePlaylist ? null : this.playlist?.toJSON() ?? null\n    } as TrackJSON;\n  }\n\n  /**\n   * Serialized track data that can be reconstructed\n   */\n  public serialize() {\n    return {\n      title: this.title,\n      description: this.description,\n      author: this.author,\n      url: this.url,\n      thumbnail: TypeUtil.isString(this.thumbnail) ? this.thumbnail : tryIntoThumbnailString(this.thumbnail),\n      duration: this.duration,\n      views: this.views ?? 0,\n      requested_by: this.requestedBy?.toJSON() ?? null,\n      source: this.source,\n      live: false,\n      query_type: this.queryType,\n      extractor: this.extractor?.identifier ?? null,\n      metadata: this.metadata,\n      $type: SerializedType.Track,\n      $encoder_version: this.player.version\n    };\n  }\n\n  /**\n   * Construct a track from serialized data\n   * @param player Player instance\n   * @param data Serialized data\n   */\n  public static fromSerialized(player: Player, data: ReturnType<Track['serialize']>) {\n    if (data.$type !== SerializedType.Track) throw new InvalidArgTypeError('data', 'SerializedTrack', 'malformed data');\n    const track = new Track(player, {\n      ...data,\n      requestedBy: data.requested_by ?\n      (() => {\n        const res = data.requested_by as APIUser;\n        try {\n          const resolved = player.client.users.resolve(res.id);\n          if (resolved) return resolved;\n          if (player.client.users.cache.has(res.id)) return player.client.users.cache.get(res.id)!;\n          // @ts-expect-error\n          const user = new User(player.client, res);\n          return user;\n        } catch {\n          return null;\n        }\n      })() :\n      null,\n      queryType: data.query_type ?? undefined\n    });\n\n    track.setMetadata(data.metadata);\n\n    return track;\n  }\n\n  /**\n   * Get belonging queues of this track\n   */\n  public getBelongingQueues() {\n    const nodes = this.player.nodes.cache.filter((node) => node.tracks.some((t) => t.id === this.id));\n\n    return nodes as Collection<string, GuildQueue<unknown>>;\n  }\n\n  /**\n   * Play this track to the given voice channel. If queue exists and another track is being played, this track will be added to the queue.\n   * @param channel Voice channel on which this track shall be played\n   * @param options Node initialization options\n   */\n  public async play<T = unknown>(\n  channel: GuildVoiceChannelResolvable,\n  options?: PlayerNodeInitializerOptions<T>)\n  : Promise<PlayerNodeInitializationResult<T>> {\n    const fn = this.player.play.bind(this.player);\n\n    return await fn(channel, this, options);\n  }\n}", "export class DiscordPlayerError extends Error {\n  public readonly code: ErrorCodes;\n  public readonly timestamp: number = Date.now();\n\n  public constructor(code: ErrorCodes, message: string) {\n    super(message);\n    this.name = this.constructor.name;\n    this.code = code;\n\n    if (Error.captureStackTrace) {\n      Error.captureStackTrace(this, this.constructor);\n    }\n  }\n\n  public toJSON() {\n    return {\n      name: this.constructor.name,\n      code: this.code,\n      message: this.message,\n      timestamp: this.timestamp\n    };\n  }\n}\n\nexport class OutOfSpaceError extends DiscordPlayerError {\n  constructor(target: string, capacity: number, total: number) {\n    super(ErrorCodes.ERR_OUT_OF_SPACE, `Max capacity reached for ${target} (Capacity ${capacity}/Total ${total})`);\n  }\n}\n\nexport class InvalidArgTypeError extends DiscordPlayerError {\n  constructor(target: string, expectation: string, found: string) {\n    super(ErrorCodes.ERR_INVALID_ARG_TYPE, `Expected ${target} to be \"${expectation}\", received \"${found}\"`);\n  }\n}\n\nexport class NoResultError extends DiscordPlayerError {\n  constructor(message: string) {\n    super(ErrorCodes.ERR_NO_RESULT, message);\n  }\n}\n\nexport class NotImplementedError extends DiscordPlayerError {\n  constructor(target: string) {\n    super(ErrorCodes.ERR_NOT_IMPLEMENTED, `${target} is not yet implemented`);\n  }\n}\n\nexport class NotExistingError extends DiscordPlayerError {\n  constructor(target: string) {\n    super(ErrorCodes.ERR_NOT_EXISTING, `${target} does not exist`);\n  }\n}\n\nexport class OutOfRangeError extends DiscordPlayerError {\n  constructor(target: string, value: string, minimum: string, maximum: string) {\n    super(\n      ErrorCodes.ERR_OUT_OF_RANGE,\n      `${target} is out of range (Expected minimum ${minimum} and maximum ${maximum}, got ${value})`\n    );\n  }\n}\n\nexport class NoVoiceConnectionError extends DiscordPlayerError {\n  constructor(message?: string) {\n    super(\n      ErrorCodes.ERR_NO_VOICE_CONNECTION,\n      message || 'No voice connection available, maybe connect to a voice channel first?'\n    );\n  }\n}\n\nexport class VoiceConnectionDestroyedError extends DiscordPlayerError {\n  constructor() {\n    super(ErrorCodes.ERR_VOICE_CONNECTION_DESTROYED, 'Cannot use destroyed voice connection');\n  }\n}\n\nexport class NoVoiceChannelError extends DiscordPlayerError {\n  constructor() {\n    super(ErrorCodes.ERR_NO_VOICE_CHANNEL, 'Could not get the voice channel');\n  }\n}\n\nexport class InvalidVoiceChannelError extends DiscordPlayerError {\n  constructor() {\n    super(ErrorCodes.ERR_INVALID_VOICE_CHANNEL, 'Expected a voice channel');\n  }\n}\n\nexport class NoReceiverError extends DiscordPlayerError {\n  constructor(message?: string) {\n    super(\n      ErrorCodes.ERR_NO_RECEIVER,\n      message || 'No voice receiver is available, maybe connect to a voice channel first?'\n    );\n  }\n}\n\nexport class FFmpegError extends DiscordPlayerError {\n  constructor(message: string) {\n    super(ErrorCodes.ERR_FFMPEG_LOCATOR, message);\n  }\n}\n\nexport class NoAudioResourceError extends DiscordPlayerError {\n  constructor(message?: string) {\n    super(ErrorCodes.ERR_NO_AUDIO_RESOURCE, message || 'Expected an audio resource');\n  }\n}\n\nexport class NoGuildQueueError extends DiscordPlayerError {\n  constructor(message?: string) {\n    super(ErrorCodes.ERR_NO_GUILD_QUEUE, message || 'Expected a guild queue');\n  }\n}\n\nexport class NoGuildError extends DiscordPlayerError {\n  constructor(message?: string) {\n    super(ErrorCodes.ERR_NO_GUILD, message || 'Expected a guild');\n  }\n}\n\nexport class InfoRequiredError extends DiscordPlayerError {\n  constructor(target: string, actual: string) {\n    super(ErrorCodes.ERR_INFO_REQUIRED, `Expected ${target}, found \"${actual}\"`);\n  }\n}\n\nexport class SerializationError extends DiscordPlayerError {\n  constructor() {\n    super(ErrorCodes.ERR_SERIALIZATION_FAILED, \"Don't know how to serialize this data\");\n  }\n}\n\nexport class DeserializationError extends DiscordPlayerError {\n  constructor() {\n    super(ErrorCodes.ERR_DESERIALIZATION_FAILED, \"Don't know how to deserialize this data\");\n  }\n}\n\nexport class IllegalHookInvocationError extends DiscordPlayerError {\n  constructor(target: string, message?: string) {\n    super(\n      ErrorCodes.ERR_ILLEGAL_HOOK_INVOCATION,\n      `Illegal invocation of ${target} hook.${message ? ` ${message}` : ''}`\n    );\n  }\n}\n\nexport class ModuleNotFoundError extends DiscordPlayerError {\n  constructor(target: string, description = '') {\n    super(\n      ErrorCodes.ERR_NOT_EXISTING_MODULE,\n      `${target} module does not exist. Install it with \\`npm install ${target}\\`.${\n      description ? ' ' + description : ''}`\n\n    );\n  }\n}\n\nexport class BridgeFailedError extends DiscordPlayerError {\n  constructor(id: string | null, error: string) {\n    super(\n      ErrorCodes.ERR_BRIDGE_FAILED,\n      `${id ? `(Extractor Execution Context ID is ${id})` : ''}Failed to bridge this query:\\n${error}`\n    );\n  }\n}\n\n// For backwards compatibility\nexport const ErrorCodes = {\n  ERR_OUT_OF_SPACE: 'ERR_OUT_OF_SPACE',\n  ERR_INVALID_ARG_TYPE: 'ERR_INVALID_ARG_TYPE',\n  ERR_NO_RESULT: 'ERR_NO_RESULT',\n  ERR_NOT_IMPLEMENTED: 'ERR_NOT_IMPLEMENTED',\n  ERR_NOT_EXISTING: 'ERR_NOT_EXISTING',\n  ERR_OUT_OF_RANGE: 'ERR_OUT_OF_RANGE',\n  ERR_NO_VOICE_CONNECTION: 'ERR_NO_VOICE_CONNECTION',\n  ERR_VOICE_CONNECTION_DESTROYED: 'ERR_VOICE_CONNECTION_DESTROYED',\n  ERR_NO_VOICE_CHANNEL: 'ERR_NO_VOICE_CHANNEL',\n  ERR_INVALID_VOICE_CHANNEL: 'ERR_INVALID_VOICE_CHANNEL',\n  ERR_NO_RECEIVER: 'ERR_NO_RECEIVER',\n  ERR_FFMPEG_LOCATOR: 'ERR_FFMPEG_LOCATOR',\n  ERR_NO_AUDIO_RESOURCE: 'ERR_NO_AUDIO_RESOURCE',\n  ERR_NO_GUILD_QUEUE: 'ERR_NO_GUILD_QUEUE',\n  ERR_NO_GUILD: 'ERR_NO_GUILD',\n  ERR_INFO_REQUIRED: 'ERR_INFO_REQUIRED',\n  ERR_SERIALIZATION_FAILED: 'ERR_SERIALIZATION_FAILED',\n  ERR_DESERIALIZATION_FAILED: 'ERR_DESERIALIZATION_FAILED',\n  ERR_ILLEGAL_HOOK_INVOCATION: 'ERR_ILLEGAL_HOOK_INVOCATION',\n  ERR_NOT_EXISTING_MODULE: 'ERR_NOT_EXISTING_MODULE',\n  ERR_BRIDGE_FAILED: 'ERR_BRIDGE_FAILED'\n} as const;\n\nexport type ErrorCodes = (typeof ErrorCodes)[keyof typeof ErrorCodes];\n\n/* eslint-disable @typescript-eslint/no-explicit-any */\n\nexport function isDiscordPlayerError(error: any): error is DiscordPlayerError {\n  return error != null && error instanceof DiscordPlayerError;\n}\n\n/**\n * Handle a `DiscordPlayerError` error.\n * @param error The error to handle\n * @param handler The handler function. This function will only be called if the error is a `DiscordPlayerError`.\n * @param args The arguments to pass to the handler\n * @returns The result of the handler\n * @example ```typescript\n * try {\n *   // ...\n * } catch (error) {\n *  handleDiscordPlayerError(error, (error) => {\n *    console.error(`An error occurred from discord-player: ${error.message}`);\n *  });\n * }\n * ```\n */\nexport function handleDiscordPlayerError<\n  T extends any[],\n  F extends (error: DiscordPlayerError, ...args: T) => any,\n  R extends ReturnType<F>>(\nerror: any, handler: F, args: T): R {\n  if (isDiscordPlayerError(error)) {\n    return handler(error, ...args) as R;\n  }\n\n  return undefined as R;\n}\n\n/* eslint-enable @typescript-eslint/no-explicit-any */", "import { DiscordPlayerError, isDiscordPlayerError } from '../errors';\n\nexport class TypeUtil {\n  private constructor() {\n    return TypeUtil;\n  }\n\n  // eslint-disable-next-line @typescript-eslint/ban-types\n  public static isFunction(t: unknown): t is Function {\n    return typeof t === 'function';\n  }\n\n  public static isNumber(t: unknown): t is number {\n    return typeof t === 'number' && !isNaN(t);\n  }\n\n  public static isString(t: unknown): t is string {\n    return typeof t === 'string';\n  }\n\n  public static isBoolean(t: unknown): t is boolean {\n    return typeof t === 'boolean';\n  }\n\n  public static isNullish(t: unknown): t is null | undefined {\n    return t == null;\n  }\n\n  public static isArray(t: unknown): t is unknown[] {\n    return Array.isArray(t);\n  }\n\n  public static isError(t: unknown): t is Error {\n    return t instanceof Error;\n  }\n\n  public static isDiscordPlayerError(t: unknown): t is DiscordPlayerError {\n    return isDiscordPlayerError(t);\n  }\n}", "/* eslint-disable @typescript-eslint/no-explicit-any */\n\nimport { DeserializationError, SerializationError } from '../errors';\nimport { Playlist, type SerializedTrack, Track, SerializedPlaylist } from '../fabric';\nimport { TypeUtil } from './TypeUtil';\nimport { Buffer } from 'buffer';\nimport { Player } from '../Player';\n\nexport enum SerializedType {\n  Track = 'track',\n  Playlist = 'playlist',\n}\n\nexport type Encodable = SerializedTrack | SerializedPlaylist;\n\nconst isTrack = (data: any): data is SerializedTrack => data.$type === SerializedType.Track;\nconst isPlaylist = (data: any): data is SerializedPlaylist => data.$type === SerializedType.Playlist;\n\nexport function serialize(data: Track | Playlist | any) {\n  if (data instanceof Track) return data.serialize();\n  if (data instanceof Playlist) return data.serialize();\n\n  try {\n    return data.toJSON();\n  } catch {\n    throw new SerializationError();\n  }\n}\n\nexport function deserialize(player: Player, data: Encodable) {\n  if (isTrack(data)) return Track.fromSerialized(player, data);\n  if (isPlaylist(data)) return Playlist.fromSerialized(player, data);\n\n  throw new DeserializationError();\n}\n\nexport function encode(data: Encodable) {\n  const str = JSON.stringify(data);\n\n  return Buffer.from(str).toString('base64');\n}\n\nexport function decode(data: string) {\n  const str = Buffer.from(data, 'base64').toString();\n\n  return JSON.parse(str);\n}\n\nexport function tryIntoThumbnailString(data: any) {\n  if (!data) return null;\n  try {\n    if (TypeUtil.isString(data)) return data;\n    return data?.url ?? data?.thumbnail?.url ?? null;\n  } catch {\n    return null;\n  }\n}", "import { Player, PlayerNodeInitializationResult, PlayerNodeInitializerOptions } from '../Player';\nimport { Track, TrackJSON, TrackSource } from './Track';\nimport { Util } from '../utils/Util';\nimport { GuildVoiceChannelResolvable } from 'discord.js';\nimport { SerializedType, tryIntoThumbnailString } from '../utils/serde';\nimport { TypeUtil } from '../utils/TypeUtil';\nimport { InvalidArgTypeError } from '../errors';\n\nexport type SerializedPlaylist = ReturnType<Playlist['serialize']>;\n\nexport interface PlaylistInitData {\n  /**\n   * The tracks of this playlist\n   */\n  tracks: Track[];\n  /**\n   * The playlist title\n   */\n  title: string;\n  /**\n   * The description\n   */\n  description: string;\n  /**\n   * The thumbnail\n   */\n  thumbnail: string;\n  /**\n   * The playlist type: `album` | `playlist`\n   */\n  type: 'album' | 'playlist';\n  /**\n   * The playlist source\n   */\n  source: TrackSource;\n  /**\n   * The playlist author\n   */\n  author: {\n    /**\n     * The author name\n     */\n    name: string;\n    /**\n     * The author url\n     */\n    url: string;\n  };\n  /**\n   * The playlist id\n   */\n  id: string;\n  /**\n   * The playlist url\n   */\n  url: string;\n  /**\n   * The raw playlist data\n   */\n  rawPlaylist?: any; // eslint-disable-line @typescript-eslint/no-explicit-any\n}\n\nexport interface PlaylistJSON {\n  /**\n   * The playlist id\n   */\n  id: string;\n  /**\n   * The playlist url\n   */\n  url: string;\n  /**\n   * The playlist title\n   */\n  title: string;\n  /**\n   * The playlist description\n   */\n  description: string;\n  /**\n   * The thumbnail\n   */\n  thumbnail: string;\n  /**\n   * The playlist type: `album` | `playlist`\n   */\n  type: 'album' | 'playlist';\n  /**\n   * The track source\n   */\n  source: TrackSource;\n  /**\n   * The playlist author\n   */\n  author: {\n    /**\n     * The author name\n     */\n    name: string;\n    /**\n     * The author url\n     */\n    url: string;\n  };\n  /**\n   * The tracks data (if any)\n   */\n  tracks: TrackJSON[];\n}\n\nexport class Playlist {\n  public readonly player: Player;\n  public tracks: Track[];\n  public title: string;\n  public description: string;\n  public thumbnail: string;\n  public type: 'album' | 'playlist';\n  public source: TrackSource;\n  public author: {\n    name: string;\n    url: string;\n  };\n  public id: string;\n  public url: string;\n  public readonly rawPlaylist?: any; // eslint-disable-line @typescript-eslint/no-explicit-any\n\n  /**\n   * Playlist constructor\n   * @param {Player} player The player\n   * @param {PlaylistInitData} data The data\n   */\n  constructor(player: Player, data: PlaylistInitData) {\n    /**\n     * The player\n     * @name Playlist#player\n     * @type {Player}\n     * @readonly\n     */\n    this.player = player;\n\n    /**\n     * The tracks in this playlist\n     * @name Playlist#tracks\n     * @type {Track[]}\n     */\n    this.tracks = data.tracks ?? [];\n\n    /**\n     * The author of this playlist\n     * @name Playlist#author\n     * @type {object}\n     */\n    this.author = data.author;\n\n    /**\n     * The description\n     * @name Playlist#description\n     * @type {string}\n     */\n    this.description = data.description;\n\n    /**\n     * The thumbnail of this playlist\n     * @name Playlist#thumbnail\n     * @type {string}\n     */\n    this.thumbnail = data.thumbnail;\n\n    /**\n     * The playlist type:\n     * - `album`\n     * - `playlist`\n     * @name Playlist#type\n     * @type {string}\n     */\n    this.type = data.type;\n\n    /**\n     * The source of this playlist:\n     * - `youtube`\n     * - `soundcloud`\n     * - `spotify`\n     * - `arbitrary`\n     * @name Playlist#source\n     * @type {string}\n     */\n    this.source = data.source;\n\n    /**\n     * The playlist id\n     * @name Playlist#id\n     * @type {string}\n     */\n    this.id = data.id;\n\n    /**\n     * The playlist url\n     * @name Playlist#url\n     * @type {string}\n     */\n    this.url = data.url;\n\n    /**\n     * The playlist title\n     * @type {string}\n     */\n    this.title = data.title;\n\n    /**\n     * @name Playlist#rawPlaylist\n     * @type {any}\n     * @readonly\n     */\n  }\n\n  *[Symbol.iterator]() {\n    yield* this.tracks;\n  }\n\n  /**\n   * Estimated duration of this playlist\n   */\n  public get estimatedDuration() {\n    return this.tracks.reduce((p, c) => p + c.durationMS, 0);\n  }\n\n  /**\n   * Formatted estimated duration of this playlist\n   */\n  public get durationFormatted() {\n    return Util.buildTimeCode(Util.parseMS(this.estimatedDuration));\n  }\n\n  /**\n   * JSON representation of this playlist\n   * @param {boolean} [withTracks=true] If it should build json with tracks\n   * @returns {PlaylistJSON}\n   */\n  toJSON(withTracks = true) {\n    const payload = {\n      id: this.id,\n      url: this.url,\n      title: this.title,\n      description: this.description,\n      thumbnail: this.thumbnail,\n      type: this.type,\n      source: this.source,\n      author: this.author,\n      tracks: [] as TrackJSON[]\n    };\n\n    if (withTracks) payload.tracks = this.tracks.map((m) => m.toJSON(true));\n\n    return payload as PlaylistJSON;\n  }\n\n  /**\n   * Serialize this playlist into reconstructable data\n   */\n  public serialize() {\n    return {\n      tracks: this.tracks.map((m) => m.serialize()),\n      title: this.title,\n      description: this.description,\n      thumbnail: TypeUtil.isString(this.thumbnail) ? this.thumbnail : tryIntoThumbnailString(this.thumbnail),\n      type: this.type,\n      source: this.source,\n      author: this.author,\n      id: this.id,\n      url: this.url,\n      $type: SerializedType.Playlist,\n      $encoder_version: this.player.version\n    };\n  }\n\n  /**\n   * Deserialize this playlist from serialized data\n   * @param player Player instance\n   * @param data Serialized data\n   */\n  public static fromSerialized(player: Player, data: SerializedPlaylist) {\n    if (data.$type !== SerializedType.Playlist)\n    throw new InvalidArgTypeError('data', 'SerializedPlaylist', 'malformed data');\n    return new Playlist(player, {\n      ...data,\n      tracks: data.tracks.map((m) => Track.fromSerialized(player, m))\n    });\n  }\n\n  /**\n   * Play this playlist to the given voice channel. If queue exists and another track is being played, this playlist will be added to the queue.\n   * @param channel Voice channel on which this playlist shall be played\n   * @param options Node initialization options\n   */\n  public async play<T = unknown>(\n  channel: GuildVoiceChannelResolvable,\n  options?: PlayerNodeInitializerOptions<T>)\n  : Promise<PlayerNodeInitializationResult<T>> {\n    const fn = this.player.play.bind(this.player);\n\n    return await fn(channel, this, options);\n  }\n}", "import { TypeUtil } from './TypeUtil';\nimport { InfoRequiredError, InvalidArgTypeError } from '../errors';\nimport { fetch } from 'undici';\n\n// #region scary things below *sigh*\nconst spotifySongRegex =\n/^https?:\\/\\/(?:embed\\.|open\\.)(?:spotify\\.com\\/)(intl-([a-z]|[A-Z])+\\/)?(?:track\\/|\\?uri=spotify:track:)((\\w|-){22})(\\?si=.+)?$/;\nconst spotifyPlaylistRegex =\n/^https?:\\/\\/(?:embed\\.|open\\.)(?:spotify\\.com\\/)(intl-([a-z]|[A-Z])+\\/)?(?:playlist\\/|\\?uri=spotify:playlist:)((\\w|-){22})(\\?si=.+)?$/;\nconst spotifyAlbumRegex =\n/^https?:\\/\\/(?:embed\\.|open\\.)(?:spotify\\.com\\/)(intl-([a-z]|[A-Z])+\\/)?(?:album\\/|\\?uri=spotify:album:)((\\w|-){22})(\\?si=.+)?$/;\nconst vimeoRegex =\n/^(http|https)?:\\/\\/(www\\.|player\\.)?vimeo\\.com\\/(?:channels\\/(?:\\w+\\/)?|groups\\/([^/]*)\\/videos\\/|video\\/|)(\\d+)(?:|\\/\\?)$/;\nconst reverbnationRegex = /^https:\\/\\/(www.)?reverbnation.com\\/(.+)\\/song\\/(.+)$/;\nconst attachmentRegex = /^https?:\\/\\/.+$/;\nconst appleMusicSongRegex = /^https?:\\/\\/music\\.apple\\.com\\/.+?\\/(song|album)\\/.+?(\\/.+?\\?i=|\\/)([0-9]+)$/;\nconst appleMusicPlaylistRegex = /^https?:\\/\\/music\\.apple\\.com\\/.+?\\/playlist\\/.+\\/pl\\.(u-|pm-)?[a-zA-Z0-9]+$/;\nconst appleMusicAlbumRegex = /^https?:\\/\\/music\\.apple\\.com\\/.+?\\/album\\/.+\\/([0-9]+)$/;\nconst soundcloudTrackRegex = /^https?:\\/\\/(m.|www.)?soundcloud.com\\/(\\w|-)+\\/(\\w|-)+(.+)?$/;\nconst soundcloudPlaylistRegex = /^https?:\\/\\/(m.|www.)?soundcloud.com\\/(\\w|-)+\\/sets\\/(\\w|-)+(.+)?$/;\nconst youtubePlaylistRegex =\n/^https?:\\/\\/(www.)?youtube.com\\/playlist\\?list=((PL|FL|UU|LL|RD|OL)[a-zA-Z0-9-_]{16,41})$/;\nconst youtubeVideoURLRegex =\n/^((?:https?:)?\\/\\/)?((?:www|m)\\.)?((?:youtube\\.com|youtu.be))(\\/(?:[\\w-]+\\?v=|embed\\/|v\\/)?)([\\w-]+)(\\S+)?$/;\nconst youtubeVideoIdRegex = /^[a-zA-Z0-9-_]{11}$/;\n// discord-player://blob/uuid-v4\nconst discordPlayerBlobRegex = /^discord-player:\\/\\/blob\\/\\d+$/;\n// #endregion scary things above *sigh*\n\nconst DomainsMap = {\n  DiscordPlayer: ['discord-player'],\n  YouTube: ['youtube.com', 'youtu.be', 'music.youtube.com', 'gaming.youtube.com', 'www.youtube.com', 'm.youtube.com'],\n  Spotify: ['open.spotify.com', 'embed.spotify.com'],\n  Vimeo: ['vimeo.com', 'player.vimeo.com'],\n  ReverbNation: ['reverbnation.com'],\n  SoundCloud: ['soundcloud.com'],\n  AppleMusic: ['music.apple.com']\n};\n\n// prettier-ignore\nconst redirectDomains = new Set([\n/^https?:\\/\\/spotify.link\\/[A-Za-z0-9]+$/,\n/^https:\\/\\/on\\.soundcloud\\.com\\/[a-zA-Z1-9]{0,17}$/]\n);\n\n/**\n * The search query type\n * This can be one of:\n * - AUTO\n * - YOUTUBE\n * - YOUTUBE_PLAYLIST\n * - SOUNDCLOUD_TRACK\n * - SOUNDCLOUD_PLAYLIST\n * - SOUNDCLOUD\n * - SPOTIFY_SONG\n * - SPOTIFY_ALBUM\n * - SPOTIFY_PLAYLIST\n * - SPOTIFY_SEARCH\n * - FACEBOOK\n * - VIMEO\n * - ARBITRARY\n * - REVERBNATION\n * - YOUTUBE_SEARCH\n * - YOUTUBE_VIDEO\n * - SOUNDCLOUD_SEARCH\n * - APPLE_MUSIC_SONG\n * - APPLE_MUSIC_ALBUM\n * - APPLE_MUSIC_PLAYLIST\n * - APPLE_MUSIC_SEARCH\n * - FILE\n * - AUTO_SEARCH\n * - DISCORD_PLAYER_BLOB\n * @typedef {string} QueryType\n */\nexport const QueryType = {\n  AUTO: 'auto',\n  YOUTUBE: 'youtube',\n  YOUTUBE_PLAYLIST: 'youtubePlaylist',\n  SOUNDCLOUD_TRACK: 'soundcloudTrack',\n  SOUNDCLOUD_PLAYLIST: 'soundcloudPlaylist',\n  SOUNDCLOUD: 'soundcloud',\n  SPOTIFY_SONG: 'spotifySong',\n  SPOTIFY_ALBUM: 'spotifyAlbum',\n  SPOTIFY_PLAYLIST: 'spotifyPlaylist',\n  SPOTIFY_SEARCH: 'spotifySearch',\n  FACEBOOK: 'facebook',\n  VIMEO: 'vimeo',\n  ARBITRARY: 'arbitrary',\n  REVERBNATION: 'reverbnation',\n  YOUTUBE_SEARCH: 'youtubeSearch',\n  YOUTUBE_VIDEO: 'youtubeVideo',\n  SOUNDCLOUD_SEARCH: 'soundcloudSearch',\n  APPLE_MUSIC_SONG: 'appleMusicSong',\n  APPLE_MUSIC_ALBUM: 'appleMusicAlbum',\n  APPLE_MUSIC_PLAYLIST: 'appleMusicPlaylist',\n  APPLE_MUSIC_SEARCH: 'appleMusicSearch',\n  FILE: 'file',\n  AUTO_SEARCH: 'autoSearch',\n  DISCORD_PLAYER_BLOB: 'discordPlayerBlob'\n} as const;\n\nexport type QueryType = (typeof QueryType)[keyof typeof QueryType];\n\nexport type SearchQueryType = keyof typeof QueryType | QueryType;\n\nexport interface ResolvedQuery {\n  type: (typeof QueryType)[keyof typeof QueryType];\n  query: string;\n}\n\nclass QueryResolver {\n  /**\n   * Query resolver\n   */\n  private constructor() {} // eslint-disable-line @typescript-eslint/no-empty-function\n\n  static get regex() {\n    return {\n      spotifyAlbumRegex,\n      spotifyPlaylistRegex,\n      spotifySongRegex,\n      vimeoRegex,\n      reverbnationRegex,\n      attachmentRegex,\n      appleMusicAlbumRegex,\n      appleMusicPlaylistRegex,\n      appleMusicSongRegex,\n      soundcloudTrackRegex,\n      soundcloudPlaylistRegex,\n      youtubePlaylistRegex,\n      discordPlayerBlobRegex\n    };\n  }\n\n  /**\n   * Pre-resolve redirect urls\n   */\n  static async preResolve(query: string, maxDepth = 5): Promise<string> {\n    if (!TypeUtil.isString(query)) throw new InvalidArgTypeError(query, 'string', typeof query);\n\n    for (const domain of redirectDomains) {\n      if (domain.test(query)) {\n        try {\n          const res = await fetch(query, {\n            method: 'GET',\n            redirect: 'follow'\n          });\n\n          if (!res.ok) break;\n\n          // spotify does not \"redirect\", it returns a page with js that redirects\n          if (/^https?:\\/\\/spotify.app.link\\/(.+)$/.test(res.url)) {\n            const body = await res.text();\n            const target = body.split('https://open.spotify.com/track/')[1].split('?si=')[0];\n\n            if (!target) break;\n\n            return `https://open.spotify.com/track/${target}`;\n          }\n          return maxDepth < 1 ? res.url : this.preResolve(res.url, maxDepth - 1);\n        } catch {\n          break;\n        }\n      }\n    }\n\n    return query;\n  }\n\n  /**\n   * Resolves the given search query\n   * @param {string} query The query\n   */\n  static resolve(\n  query: string,\n  fallbackSearchEngine: (typeof QueryType)[keyof typeof QueryType] = QueryType.AUTO_SEARCH)\n  : ResolvedQuery {\n    if (!TypeUtil.isString(query)) throw new InvalidArgTypeError(query, 'string', typeof query);\n    if (!query.length) throw new InfoRequiredError('query', String(query));\n\n    const resolver = (type: typeof fallbackSearchEngine, query: string) => ({ type, query });\n\n    if (discordPlayerBlobRegex.test(query)) return resolver(QueryType.DISCORD_PLAYER_BLOB, query);\n\n    try {\n      const url = new URL(query);\n\n      if (DomainsMap.YouTube.includes(url.host)) {\n        query = query.replace(/(m(usic)?|gaming)\\./, '').trim();\n        const playlistId = url.searchParams.get('list');\n        const videoId = url.searchParams.get('v');\n        if (playlistId) {\n          if (videoId && playlistId.startsWith('RD'))\n          return resolver(\n            QueryType.YOUTUBE_PLAYLIST,\n            `https://www.youtube.com/watch?v=${videoId}&list=${playlistId}`\n          );\n          return resolver(QueryType.YOUTUBE_PLAYLIST, `https://www.youtube.com/playlist?list=${playlistId}`);\n        }\n        if (QueryResolver.validateId(query) || QueryResolver.validateURL(query))\n        return resolver(QueryType.YOUTUBE_VIDEO, query);\n        return resolver(fallbackSearchEngine, query);\n      } else if (DomainsMap.Spotify.includes(url.host)) {\n        query = query.replace(/intl-([a-zA-Z]+)\\//, '');\n        if (spotifyPlaylistRegex.test(query)) return resolver(QueryType.SPOTIFY_PLAYLIST, query);\n        if (spotifyAlbumRegex.test(query)) return resolver(QueryType.SPOTIFY_ALBUM, query);\n        if (spotifySongRegex.test(query)) return resolver(QueryType.SPOTIFY_SONG, query);\n        return resolver(fallbackSearchEngine, query);\n      } else if (DomainsMap.Vimeo.includes(url.host)) {\n        if (vimeoRegex.test(query)) return resolver(QueryType.VIMEO, query);\n        return resolver(fallbackSearchEngine, query);\n      } else if (DomainsMap.ReverbNation.includes(url.host)) {\n        if (reverbnationRegex.test(query)) return resolver(QueryType.REVERBNATION, query);\n        return resolver(fallbackSearchEngine, query);\n      } else if (DomainsMap.SoundCloud.includes(url.host)) {\n        if (soundcloudPlaylistRegex.test(query)) return resolver(QueryType.SOUNDCLOUD_PLAYLIST, query);\n        if (soundcloudTrackRegex.test(query)) return resolver(QueryType.SOUNDCLOUD_TRACK, query);\n        return resolver(fallbackSearchEngine, query);\n      } else if (DomainsMap.AppleMusic.includes(url.host)) {\n        if (appleMusicAlbumRegex.test(query)) return resolver(QueryType.APPLE_MUSIC_ALBUM, query);\n        if (appleMusicPlaylistRegex.test(query)) return resolver(QueryType.APPLE_MUSIC_PLAYLIST, query);\n        if (appleMusicSongRegex.test(query)) return resolver(QueryType.APPLE_MUSIC_SONG, query);\n        return resolver(fallbackSearchEngine, query);\n      } else {\n        return resolver(QueryType.ARBITRARY, query);\n      }\n    } catch {\n      return resolver(fallbackSearchEngine, query);\n    }\n  }\n\n  /**\n   * Parses vimeo id from url\n   * @param {string} query The query\n   * @returns {string}\n   */\n  static getVimeoID(query: string): string | null | undefined {\n    return QueryResolver.resolve(query).type === QueryType.VIMEO ? query.split('/').filter(Boolean).pop() : null;\n  }\n\n  static validateId(q: string) {\n    return youtubeVideoIdRegex.test(q);\n  }\n\n  static validateURL(q: string) {\n    return youtubeVideoURLRegex.test(q);\n  }\n}\n\nexport { QueryResolver };", "import { User, UserResolvable } from 'discord.js';\nimport { BaseExtractor } from '../extractors/BaseExtractor';\nimport { Player } from '../Player';\nimport { Playlist } from './Playlist';\nimport { Track } from './Track';\nimport { QueryType, SearchQueryType } from '../utils/QueryResolver';\n\nexport interface SearchResultData {\n  query: string;\n  queryType?: SearchQueryType | QueryExtractorSearch | null;\n  extractor?: BaseExtractor | null;\n  playlist?: Playlist | null;\n  tracks?: Track[];\n  requestedBy?: User | null;\n}\n\nexport interface PlayOptions {\n  /**\n   * If this play was triggered for filters update\n   */\n  filtersUpdate?: boolean;\n  /**\n   * FFmpeg args passed to encoder\n   */\n  encoderArgs?: string[];\n  /**\n   * Time to seek to before playing\n   */\n  seek?: number;\n  /**\n   * If it should start playing the provided track immediately\n   */\n  immediate?: boolean;\n}\n\nexport type QueryExtractorSearch = `ext:${string}`;\n\nexport interface SearchOptions {\n  /**\n   * The user who requested this search\n   */\n  requestedBy?: UserResolvable;\n  /**\n   * The query search engine, can be extractor name to target specific one (custom)\n   */\n  searchEngine?: SearchQueryType | QueryExtractorSearch;\n  /**\n   * List of the extractors to block\n   */\n  blockExtractors?: string[];\n  /**\n   * If it should ignore query cache lookup\n   */\n  ignoreCache?: boolean;\n  /**\n   * Fallback search engine to use\n   */\n  // eslint-disable-next-line @typescript-eslint/no-explicit-any\n  requestOptions?: any;\n  /**\n   * Fallback search engine to use\n   */\n  fallbackSearchEngine?: (typeof QueryType)[keyof typeof QueryType];\n}\n\nexport interface PlayerSearchResult {\n  playlist: Playlist | null;\n  tracks: Track[];\n}\n\nexport class SearchResult {\n  public constructor(public player: Player, private _data: SearchResultData) {\n    this._data.tracks?.forEach((track) => {\n      track.extractor ??= this._data.extractor || null;\n      track.requestedBy ??= _data.requestedBy || null;\n    });\n  }\n\n  public setQueryType(type: SearchQueryType | QueryExtractorSearch) {\n    this._data.queryType = type;\n    return this;\n  }\n\n  public setRequestedBy(user: User) {\n    this._data.requestedBy = user;\n    this._data.tracks?.forEach((track) => {\n      track.requestedBy = user;\n    });\n    return this;\n  }\n\n  public setExtractor(extractor: BaseExtractor) {\n    this._data.extractor = extractor;\n    this._data.tracks?.forEach((track) => {\n      track.extractor = extractor;\n    });\n    return this;\n  }\n\n  public setTracks(tracks: Track[]) {\n    this._data.tracks = tracks;\n    return this;\n  }\n\n  public setQuery(query: string) {\n    this._data.query = query;\n    return this;\n  }\n\n  public setPlaylist(playlist: Playlist) {\n    this._data.playlist = playlist;\n    return this;\n  }\n\n  /**\n   * The search query\n   */\n  public get query() {\n    return this._data.query;\n  }\n\n  /**\n   * The search query type\n   */\n  public get queryType() {\n    return this._data.queryType || QueryType.AUTO;\n  }\n\n  /**\n   * The extractor\n   */\n  public get extractor() {\n    return this._data.extractor || null;\n  }\n\n  /**\n   * Playlist result\n   */\n  public get playlist() {\n    return this._data.playlist;\n  }\n\n  /**\n   * Tracks result\n   */\n  public get tracks() {\n    return this._data.tracks || [];\n  }\n\n  /**\n   * Requested by\n   */\n  public get requestedBy() {\n    return this._data.requestedBy || null;\n  }\n\n  /**\n   * Re-execute this search\n   */\n  public async execute() {\n    return this.player.search(this.query, {\n      searchEngine: this.queryType,\n      requestedBy: this.requestedBy!\n    });\n  }\n\n  /**\n   * If this search result is empty\n   */\n  public isEmpty() {\n    return !this.tracks.length;\n  }\n\n  /**\n   * If this search result has playlist\n   */\n  public hasPlaylist() {\n    return this.playlist != null;\n  }\n\n  /**\n   * If this search result has tracks\n   */\n  public hasTracks() {\n    return this.tracks.length > 0;\n  }\n\n  /**\n   * JSON representation of this search\n   */\n  public toJSON() {\n    return {\n      query: this.query,\n      queryType: this.queryType,\n      playlist: this.playlist?.toJSON(false) || null,\n      tracks: this.tracks.map((m) => m.toJSON(true)),\n      extractor: this.extractor?.identifier || null,\n      requestedBy: this.requestedBy?.toJSON() || null\n    };\n  }\n}", "export type FiltersName = keyof QueueFilters;\n\n/**\n * Represents FFmpeg filters\n */\nexport interface QueueFilters {\n  bassboost_low?: boolean;\n  bassboost?: boolean;\n  bassboost_high?: boolean;\n  '8D'?: boolean;\n  vaporwave?: boolean;\n  nightcore?: boolean;\n  phaser?: boolean;\n  tremolo?: boolean;\n  vibrato?: boolean;\n  reverse?: boolean;\n  treble?: boolean;\n  normalizer?: boolean;\n  normalizer2?: boolean;\n  surrounding?: boolean;\n  pulsator?: boolean;\n  subboost?: boolean;\n  karaoke?: boolean;\n  flanger?: boolean;\n  gate?: boolean;\n  haas?: boolean;\n  mcompand?: boolean;\n  mono?: boolean;\n  mstlr?: boolean;\n  mstrr?: boolean;\n  compressor?: boolean;\n  expander?: boolean;\n  softlimiter?: boolean;\n  chorus?: boolean;\n  chorus2d?: boolean;\n  chorus3d?: boolean;\n  fadein?: boolean;\n  dim?: boolean;\n  earrape?: boolean;\n  lofi?: boolean;\n  silenceremove?: boolean;\n}\n\nconst bass = (g: number) => `bass=g=${g}:f=110:w=0.3`;\n\nexport class AudioFilters {\n  public constructor() {\n    return AudioFilters;\n  }\n\n  public static filters: Record<FiltersName, string> = {\n    bassboost_low: bass(15),\n    bassboost: bass(20),\n    bassboost_high: bass(30),\n    '8D': 'apulsator=hz=0.09',\n    vaporwave: 'aresample=48000,asetrate=48000*0.8',\n    nightcore: 'aresample=48000,asetrate=48000*1.25',\n    lofi: 'aresample=48000,asetrate=48000*0.9,extrastereo=m=2.5:c=disabled',\n    phaser: 'aphaser=in_gain=0.4',\n    tremolo: 'tremolo',\n    vibrato: 'vibrato=f=6.5',\n    reverse: 'areverse',\n    treble: 'treble=g=5',\n    normalizer2: 'dynaudnorm=g=101',\n    normalizer: 'acompressor',\n    surrounding: 'surround',\n    pulsator: 'apulsator=hz=1',\n    subboost: 'asubboost',\n    karaoke: 'stereotools=mlev=0.03',\n    flanger: 'flanger',\n    gate: 'agate',\n    haas: 'haas',\n    mcompand: 'mcompand',\n    mono: 'pan=mono|c0=.5*c0+.5*c1',\n    mstlr: 'stereotools=mode=ms>lr',\n    mstrr: 'stereotools=mode=ms>rr',\n    compressor: 'compand=points=-80/-105|-62/-80|-15.4/-15.4|0/-12|20/-7.6',\n    expander: 'compand=attacks=0:points=-80/-169|-54/-80|-49.5/-64.6|-41.1/-41.1|-25.8/-15|-10.8/-4.5|0/0|20/8.3',\n    softlimiter: 'compand=attacks=0:points=-80/-80|-12.4/-12.4|-6/-8|0/-6.8|20/-2.8',\n    chorus: 'chorus=0.7:0.9:55:0.4:0.25:2',\n    chorus2d: 'chorus=0.6:0.9:50|60:0.4|0.32:0.25|0.4:2|1.3',\n    chorus3d: 'chorus=0.5:0.9:50|60|40:0.4|0.32|0.3:0.25|0.4|0.3:2|2.3|1.3',\n    fadein: 'afade=t=in:ss=0:d=10',\n    dim: `afftfilt=\"'real=re * (1-clip((b/nb)*b,0,1))':imag='im * (1-clip((b/nb)*b,0,1))'\"`,\n    earrape: 'channelsplit,sidechaingate=level_in=64',\n    silenceremove: 'silenceremove=1:0:-50dB'\n  };\n\n  public static get<K extends FiltersName>(name: K) {\n    return this.filters[name] ?? name;\n  }\n\n  public static has<K extends FiltersName>(name: K) {\n    return name in this.filters;\n  }\n\n  public static *[Symbol.iterator](): IterableIterator<{name: FiltersName;value: string;}> {\n    for (const [k, v] of Object.entries(this.filters)) {\n      yield { name: k as FiltersName, value: v as string };\n    }\n  }\n\n  public static get names() {\n    return Object.keys(this.filters) as FiltersName[];\n  }\n\n  // @ts-ignore\n  public static get length() {\n    return this.names.length;\n  }\n\n  public static toString() {\n    return this.names.map((m) => (this as any)[m]).join(','); // eslint-disable-line @typescript-eslint/no-explicit-any\n  }\n\n  /**\n   * Create ffmpeg args from the specified filters name\n   * @param filter The filter name\n   * @returns\n   */\n  public static create<K extends FiltersName>(filters?: (K | string)[]) {\n    if (!filters || !Array.isArray(filters)) return this.toString();\n    return filters.\n    filter((predicate) => typeof predicate === 'string').\n    map((m) => this.get(m as K)).\n    join(',');\n  }\n\n  /**\n   * Defines audio filter\n   * @param filterName The name of the filter\n   * @param value The ffmpeg args\n   */\n  public static define(filterName: string, value: string) {\n    this.filters[filterName as FiltersName] = value;\n  }\n\n  /**\n   * Defines multiple audio filters\n   * @param filtersArray Array of filters containing the filter name and ffmpeg args\n   */\n  public static defineBulk(filtersArray: {name: string;value: string;}[]) {\n    filtersArray.forEach((arr) => this.define(arr.name, arr.value));\n  }\n}", "import { DefaultListener } from '@discord-player/utils';\nimport { ListenerSignature } from '@discord-player/utils';\nimport { EventEmitter } from '@discord-player/utils';\nimport { Util } from './Util';\n\nexport class PlayerEventsEmitter<L extends ListenerSignature<L> = DefaultListener> extends EventEmitter<L> {\n  #hasDebugger = false;\n  public constructor(public requiredEvents: Array<keyof L> = []) {\n    super();\n  }\n\n  public on<K extends keyof L>(name: K, listener: L[K]) {\n    if (name === 'debug') {\n      this.#hasDebugger = true;\n    }\n\n    return super.on(name, listener);\n  }\n\n  public once<K extends keyof L>(name: K, listener: L[K]) {\n    if (name === 'debug') {\n      this.#hasDebugger = true;\n    }\n\n    return super.once(name, listener);\n  }\n\n  public addListener<K extends keyof L>(name: K, listener: L[K]) {\n    if (name === 'debug') {\n      this.#hasDebugger = true;\n    }\n\n    return super.addListener(name, listener);\n  }\n\n  public off<K extends keyof L>(name: K, listener: L[K]) {\n    this.#hasDebugger = this.listenerCount('debug' as K) > 0;\n\n    return super.off(name, listener);\n  }\n\n  public removeListener<K extends keyof L>(name: K, listener: L[K]) {\n    this.#hasDebugger = this.listenerCount('debug' as K) > 0;\n\n    return super.removeListener(name, listener);\n  }\n\n  public removeAllListeners<K extends keyof L>(name?: K) {\n    this.#hasDebugger = this.listenerCount('debug' as K) > 0;\n\n    return super.removeAllListeners(name);\n  }\n\n  public emit<K extends keyof L>(name: K, ...args: Parameters<L[K]>) {\n    if (this.requiredEvents.includes(name) && !this.eventNames().includes(name)) {\n      // eslint-disable-next-line no-console\n      console.error(...args);\n      Util.warn(\n        `No event listener found for event \"${String(name)}\". Events ${this.requiredEvents.\n        map((m) => `\"${String(m)}\"`).\n        join(', ')} must have event listeners.`,\n        'UnhandledEventsWarning'\n      );\n      return false;\n    }\n\n    return super.emit(name, ...args);\n  }\n\n  public get hasDebugger() {\n    return this.#hasDebugger;\n  }\n}", "import { User } from 'discord.js';\nimport { Readable } from 'stream';\nimport { Playlist } from '../fabric/Playlist';\nimport { Track } from '../fabric/Track';\nimport { ExtractorExecutionContext } from './ExtractorExecutionContext';\nimport type { RequestOptions } from 'http';\nimport { NotImplementedError } from '../errors';\nimport type { GuildQueueHistory } from '../queue';\nimport { SearchQueryType } from '../utils/QueryResolver';\nimport { PlayerEvents } from '../Player';\n\nexport type ExtractorStreamable =\nReadable |\nstring |\n{\n  $fmt: string;\n  stream: Readable;\n};\n\nexport class BaseExtractor<T extends object = object> {\n  /**\n   * Identifier for this extractor\n   */\n  public static identifier = 'com.discord-player.extractor';\n\n  /**\n   * Priority of this extractor. Higher value means higher priority (will be executed first).\n   */\n  public priority = 1;\n\n  /**\n   * A list of query protocols that this extractor supports.\n   */\n  public protocols: string[] = [];\n\n  /**\n   * Handle bridge query creation\n   * @param track The track to build query for\n   */\n  public createBridgeQuery = (track: Track) => `${track.title} by ${track.author} official audio`;\n\n  /**\n   * Extractor constructor\n   * @param context Context that instantiated this extractor\n   * @param options Initialization options for this extractor\n   */\n  public constructor(public context: ExtractorExecutionContext, public options: T = <T> {}) {}\n\n  /**\n   * Identifier of this extractor\n   */\n  public get identifier() {\n    return (this.constructor as typeof BaseExtractor).identifier;\n  }\n\n  /**\n   * Reconfigures this extractor\n   * @param options The new options to apply\n   */\n  public async reconfigure(options: T) {\n    this.options = options;\n    await this.deactivate();\n    await this.activate();\n  }\n\n  /**\n   * This method will be executed when this extractor is activated\n   */\n  public async activate() {\n    // executed when this extractor is activated\n    return;\n  }\n\n  /**\n   * This method will be executed when this extractor is deactivated\n   */\n  public async deactivate() {\n    // executed when this extractor is deactivated\n    return;\n  }\n\n  /**\n   * Validate incoming query\n   * @param query The query to validate\n   */\n  public async validate(query: string, type?: SearchQueryType | null): Promise<boolean> {\n    void type;\n    return false;\n  }\n\n  /**\n   * Stream the given track\n   * @param info The track to stream\n   */\n  public async stream(info: Track): Promise<ExtractorStreamable> {\n    void info;\n    throw new NotImplementedError(`${this.constructor.name}.stream()`);\n  }\n\n  /**\n   * Handle the given query\n   * @param query The query to handle\n   */\n  public async handle(query: string, context: ExtractorSearchContext): Promise<ExtractorInfo> {\n    void context;\n    throw new NotImplementedError(`${this.constructor.name}.handle()`);\n  }\n\n  /**\n   * Get related tracks for the given track\n   * @param track The track source\n   */\n  public async getRelatedTracks(track: Track, history: GuildQueueHistory): Promise<ExtractorInfo> {\n    void track;\n    void history;\n    throw new NotImplementedError(`${this.constructor.name}.getRelatedTracks()`);\n  }\n\n  /**\n   * A stream middleware to handle streams before passing it to the player\n   * @param stream The incoming stream\n   * @param next The next function\n   */\n  public handlePostStream(stream: Readable, next: NextFunction) {\n    return next(null, stream);\n  }\n\n  /**\n   * Dispatch an event to the player\n   * @param event The event to dispatch\n   * @param args The data to dispatch\n   */\n  public emit<K extends keyof PlayerEvents>(event: K, ...args: Parameters<PlayerEvents[K]>) {\n    return this.context.player.emit(event, ...args);\n  }\n\n  /**\n   * Create extractor response\n   * @param playlist The playlist\n   * @param tracks The track array\n   */\n  public createResponse(playlist?: Playlist | null, tracks: Track[] = playlist?.tracks || []): ExtractorInfo {\n    return { playlist: playlist || null, tracks };\n  }\n\n  /**\n   * Write debug message\n   * @param message The debug message\n   */\n  public debug(message: string) {\n    return this.context.player.debug(message);\n  }\n\n  /**\n   * A flag to indicate `Demuxable` stream support for `opus`/`ogg/opus`/`webm/opus` formats.\n   */\n  public get supportsDemux() {\n    return !!this.context.player.options.skipFFmpeg;\n  }\n\n  /**\n   * Handle stream extraction for another extractor\n   * @param track The track to bridge\n   * @param sourceExtractor The source extractor\n   */\n  public async bridge(track: Track, sourceExtractor: BaseExtractor | null): Promise<ExtractorStreamable | null> {\n    void sourceExtractor;\n    return null;\n  }\n}\n\nexport type NextFunction = (error?: Error | null, stream?: Readable) => void;\n\nexport interface ExtractorInfo {\n  playlist: Playlist | null;\n  tracks: Track[];\n}\n\nexport interface ExtractorSearchContext {\n  type?: SearchQueryType | null;\n  requestedBy?: User | null;\n  requestOptions?: RequestOptions;\n  protocol?: string | null;\n}", "import { Player } from '../Player';\nimport { Collection } from '@discord-player/utils';\nimport { BaseExtractor, ExtractorStreamable } from './BaseExtractor';\nimport { Util } from '../utils/Util';\nimport { PlayerEventsEmitter } from '../utils/PlayerEventsEmitter';\nimport { TypeUtil } from '../utils/TypeUtil';\nimport { Track } from '../fabric';\nimport { createContext } from '../hooks';\nimport { BridgeFailedError } from '../errors';\n\nexport interface ExtractorSession {\n  id: string;\n  attemptedExtractors: Set<string>;\n  bridgeAttemptedExtractors: Set<string>;\n}\n\nexport interface ExtractorExecutionEvents {\n  /**\n   * Emitted when a extractor is registered\n   * @param context The context where extractor was registered\n   * @param extractor The extractor that was registered\n   */\n  registered: (context: ExtractorExecutionContext, extractor: BaseExtractor) => unknown;\n  /**\n   * Emitted when a extractor is unregistered\n   * @param context The context where extractor was unregistered\n   * @param extractor The extractor that was unregistered\n   */\n  unregistered: (context: ExtractorExecutionContext, extractor: BaseExtractor) => unknown;\n  /**\n   * Emitted when a extractor is activated\n   * @param context The context where this event occurred\n   * @param extractor The extractor which was activated\n   */\n  activate: (context: ExtractorExecutionContext, extractor: BaseExtractor) => unknown;\n  /**\n   * Emitted when a extractor is deactivated\n   * @param context The context where this event occurred\n   * @param extractor The extractor which was deactivated\n   */\n  deactivate: (context: ExtractorExecutionContext, extractor: BaseExtractor) => unknown;\n  /**\n   * Emitted when a extractor fails to activate/deactivate\n   * @param context The context where this event occurred\n   * @param extractor The extractor which was deactivated\n   */\n  error: (context: ExtractorExecutionContext, extractor: BaseExtractor, error: Error) => unknown;\n}\n\nexport class ExtractorExecutionContext extends PlayerEventsEmitter<ExtractorExecutionEvents> {\n  /**\n   * The extractors store\n   */\n  public store = new Collection<string, BaseExtractor>();\n\n  public readonly context = createContext<ExtractorSession>();\n\n  public constructor(public player: Player) {\n    super(['error']);\n  }\n\n  /**\n   * Get the current execution id\n   */\n  public getExecutionId(): string | null {\n    return this.context.consume()?.id ?? null;\n  }\n\n  /**\n   * Get the current execution context\n   */\n  public getContext() {\n    return this.context.consume() ?? null;\n  }\n\n  public async loadDefault() {\n    const sample = `\\timport { DefaultExtractors } from '@discord-player/extractor';\\n\\tawait player.extractors.loadMulti(DefaultExtractors);`;\n\n    throw new Error(\n      `extractors.loadDefault() is no longer supported. Use extractors.loadMulti instead. Example:\\n${sample}\\n`\n    );\n  }\n\n  /**\n   * Load a bundle of extractors.\n   * @example import { DefaultExtractors } from '@discord-player/extractor';\n   *\n   * await player.extractors.loadMulti(DefaultExtractors);\n   */\n  public async loadMulti<\n    O extends object,\n    T extends (typeof BaseExtractor<O>)[],\n    R extends Record<T[number]['identifier'], ConstructorParameters<T[number]>[1]>>(\n  bundle: T, options: R = {} as R) {\n    bundle.forEach((ext) => {\n      // @ts-ignore\n      this.register(ext, options?.[ext.identifier] || {});\n    });\n\n    return { success: true, error: null };\n  }\n\n  /**\n   * Validate if the given extractor is registered\n   * @param identifier The extractor identifier\n   */\n  public isRegistered(identifier: string) {\n    return this.store.has(identifier);\n  }\n\n  /**\n   * The size of registered extractors\n   */\n  public get size() {\n    return this.store.size;\n  }\n\n  /**\n   * Get single extractor\n   * @param identifier The extractor to get\n   */\n  public get(identifier: string) {\n    return this.store.get(identifier);\n  }\n\n  /**\n   * Register single extractor\n   * @param _extractor The extractor to register\n   * @param options Options supplied to the extractor\n   */\n  public async register<O extends object, T extends typeof BaseExtractor<O>>(\n  _extractor: T,\n  options: ConstructorParameters<T>['1'])\n  : Promise<InstanceType<T> | null> {\n    if (typeof _extractor.identifier !== 'string' || this.store.has(_extractor.identifier)) return null;\n    const extractor = new _extractor(this, options);\n\n    try {\n      this.store.set(_extractor.identifier, extractor);\n      if (this.player.hasDebugger) this.player.debug(`${_extractor.identifier} extractor loaded!`);\n      this.emit('registered', this, extractor);\n      await extractor.activate();\n      if (this.player.hasDebugger) this.player.debug(`${_extractor.identifier} extractor activated!`);\n      this.emit('activate', this, extractor);\n      return extractor as unknown as InstanceType<T>;\n    } catch (e) {\n      this.store.delete(_extractor.identifier);\n      if (this.player.hasDebugger)\n      this.player.debug(`${_extractor.identifier} extractor failed to activate! Error: ${e}`);\n      this.emit('error', this, extractor, e as Error);\n      return null;\n    }\n  }\n\n  /**\n   * Unregister single extractor\n   * @param _extractor The extractor to unregister\n   */\n  public async unregister<K extends string | BaseExtractor>(_extractor: K) {\n    const extractor =\n    typeof _extractor === 'string' ? this.store.get(_extractor) : this.store.find((r) => r === _extractor);\n    if (!extractor) return;\n\n    try {\n      const key = extractor.identifier || this.store.findKey((e) => e === extractor)!;\n      this.store.delete(key);\n      if (this.player.hasDebugger) this.player.debug(`${extractor.identifier} extractor disabled!`);\n      this.emit('unregistered', this, extractor);\n      await extractor.deactivate();\n      if (this.player.hasDebugger) this.player.debug(`${extractor.identifier} extractor deactivated!`);\n      this.emit('deactivate', this, extractor);\n    } catch (e) {\n      if (this.player.hasDebugger) this.player.debug(`${extractor.identifier} extractor failed to deactivate!`);\n      this.emit('error', this, extractor, e as Error);\n    }\n  }\n\n  /**\n   * Unregister all extractors\n   */\n  public async unregisterAll() {\n    try {\n      await Promise.all(this.store.map((e) => this.unregister(e)));\n    } catch {\n\n      // do nothing\n    }}\n\n  /**\n   * Run all the extractors\n   * @param fn The runner function\n   * @param filterBlocked Filter blocked extractors\n   */\n  public async run<T = unknown>(fn: ExtractorExecutionFN<T>, filterBlocked = true) {\n    const blocked = this.player.options.blockExtractors ?? [];\n\n    if (!this.store.size) {\n      Util.warn('Skipping extractors execution since zero extractors were registered', 'NoExtractors');\n      return;\n    }\n\n    // sort by priority so that extractors with higher priority are executed first\n    const extractors = this.store.sort((a, b) => b.priority - a.priority);\n\n    let err: Error | null = null,\n      lastExt: BaseExtractor | null = null;\n\n    for (const ext of extractors.values()) {\n      if (filterBlocked && blocked.some((e) => e === ext.identifier)) continue;\n      if (this.player.hasDebugger) this.player.debug(`Executing extractor ${ext.identifier}...`);\n      const result = await fn(ext).then(\n        (res) => {\n          return res;\n        },\n        (e) => {\n          if (this.player.hasDebugger) this.player.debug(`Extractor ${ext.identifier} failed with error: ${e}`);\n\n          return TypeUtil.isError(e) ? e : new Error(`${e}`);\n        }\n      );\n\n      lastExt = ext;\n\n      if (result && !TypeUtil.isError(result)) {\n        if (this.player.hasDebugger) this.player.debug(`Extractor ${ext.identifier} executed successfully!`);\n\n        return {\n          extractor: ext,\n          error: null,\n          result\n        } as ExtractorExecutionResult<T>;\n      } else if (TypeUtil.isError(result)) {\n        err = result;\n      }\n    }\n\n    if (err)\n    return {\n      extractor: lastExt!,\n      error: err,\n      result: false\n    } as ExtractorExecutionResult<false>;\n  }\n\n  /**\n   * Request bridge for a track\n   * @param track The track to request bridge for\n   * @param sourceExtractor The source extractor of the track\n   */\n  public async requestBridge(track: Track, sourceExtractor: BaseExtractor | null = track.extractor) {\n    const previouslyAttempted = this.getContext()?.bridgeAttemptedExtractors ?? new Set<string>();\n\n    const result = await this.run<ExtractorStreamable>(async (ext) => {\n      if (sourceExtractor && ext.identifier === sourceExtractor.identifier) return false;\n      if (previouslyAttempted.has(ext.identifier)) return false;\n\n      previouslyAttempted.add(ext.identifier);\n\n      const result = await ext.bridge(track, sourceExtractor);\n\n      if (!result) return false;\n\n      return result;\n    });\n\n    if (!result?.result)\n    throw new BridgeFailedError(\n      this.getExecutionId(),\n      result?.error?.stack || result?.error?.message || 'No extractors available to bridge'\n    );\n\n    track.bridgedExtractor = result.extractor;\n\n    return result;\n  }\n\n  /**\n   * Request bridge from the specified extractor\n   * @param track The track to request bridge for\n   * @param sourceExtractor The source extractor of the track\n   * @param targetExtractor The target extractor to bridge to\n   */\n  public async requestBridgeFrom(\n  track: Track,\n  sourceExtractor: BaseExtractor | null,\n  targetExtractor: ExtractorResolvable)\n  {\n    const target = this.resolve(targetExtractor);\n    if (!target) return null;\n    return target.bridge(track, sourceExtractor);\n  }\n\n  /**\n   * Check if extractor is disabled\n   */\n  public isDisabled(identifier: string) {\n    return this.player.options.blockExtractors?.includes(identifier) ?? false;\n  }\n\n  /**\n   * Check if extractor is enabled\n   */\n  public isEnabled(identifier: string) {\n    return !this.isDisabled(identifier);\n  }\n\n  /**\n   * Resolve extractor identifier\n   */\n  public resolveId(resolvable: ExtractorResolvable) {\n    return typeof resolvable === 'string' ? resolvable : resolvable.identifier;\n  }\n\n  /**\n   * Resolve extractor\n   */\n  public resolve(resolvable: ExtractorResolvable) {\n    return typeof resolvable === 'string' ? this.get(resolvable) : resolvable;\n  }\n}\n\nexport interface ExtractorExecutionResult<T = unknown> {\n  extractor: BaseExtractor;\n  error: Error | null;\n  result: T;\n}\n\nexport type ExtractorExecutionFN<T = unknown> = (extractor: BaseExtractor) => Promise<T | boolean>;\n\nexport type ExtractorResolvable = string | BaseExtractor;", "import { AsyncLocalStorage } from 'node:async_hooks';\n\n// eslint-disable-next-line @typescript-eslint/no-explicit-any\ntype unsafe = any;\n\n/**\n * The receiver function that will be called when the context is provided\n */\nexport type ContextReceiver<R> = () => R;\n\nexport class Context<T> {\n  private storage = new AsyncLocalStorage<T>();\n\n  public constructor(private defaultValue?: T) {}\n\n  /**\n   * Exit out of this context\n   */\n  public exit(scope: ContextReceiver<void>) {\n    this.storage.exit(scope);\n  }\n\n  /**\n   * Whether the context is lost\n   */\n  public get isLost() {\n    return this.storage.getStore() === undefined;\n  }\n\n  /**\n   * Get the current value of the context. If the context is lost and no default value is provided, undefined will be returned.\n   */\n  public consume(): T | undefined {\n    const data = this.storage.getStore();\n\n    if (data === undefined && this.defaultValue !== undefined) return this.defaultValue;\n\n    return data;\n  }\n\n  /**\n   * Run a function within the context of this provider\n   */\n  public provide<R = unsafe>(value: T, receiver: ContextReceiver<R>): R {\n    if (value === undefined) {\n      throw new Error('Context value may not be undefined');\n    }\n\n    if (typeof receiver !== 'function') {\n      throw new Error('Context receiver must be a function');\n    }\n\n    return this.storage.run(value, receiver);\n  }\n}\n\n/**\n * Create a new context. The default value is optional.\n * @param defaultValue The default value of the context\n * @example const userContext = createContext();\n *\n *  // the value to provide\n *  const user = {\n *   id: 1,\n *   name: 'John Doe'\n *  };\n *\n *  // provide the context value to the receiver\n *  context.provide(user, handler);\n *\n *  function handler() {\n *    // get the context value\n *    const { id, name } = useContext(context);\n *\n *    console.log(id, name); // 1, John Doe\n *  }\n */\nexport function createContext<T = unsafe>(defaultValue?: T): Context<T> {\n  return new Context(defaultValue);\n}\n\n/**\n * Get the current value of the context. If the context is lost and no default value is provided, undefined will be returned.\n * @param context The context to get the value from\n * @example const value = useContext(context);\n */\nexport function useContext<T = unsafe>(context: Context<T>): T | undefined {\n  return context.consume();\n}", "import { Collection } from '@discord-player/utils';\n\nexport const globalRegistry = new Collection<string, unknown>();", "import { globalRegistry } from './_container';\n\nexport function getGlobalRegistry() {\n  return globalRegistry;\n}", "import { Guild } from 'discord.js';\nimport { Player } from '../Player';\nimport { IllegalHookInvocationError } from '../errors';\nimport { createContext, useContext } from './context/async-context';\nimport { getGlobalRegistry } from '../utils/__internal__';\n\nexport interface HooksCtx {\n  guild: Guild;\n}\n\nexport const SUPER_CONTEXT = createContext<Player>();\n\nconst getFallbackContext = () => {\n  return getGlobalRegistry().get('@[player]') as Player | undefined;\n};\n\n/**\n * @private\n */\nexport function useHooksContext(hookName: string, mainOnly = false) {\n  let isFallback = false;\n\n  let player: Player | undefined;\n\n  if (!(player = SUPER_CONTEXT.consume())) {\n    player = getFallbackContext();\n    isFallback = true;\n  }\n\n  if (!player)\n  throw new IllegalHookInvocationError(\n    'discord-player',\n    `Player context is not available, ${\n    isFallback ?\n    'did you forget to initialize the player with `new Player(client)`?' :\n    'is it being called inside <Player>.context.provide()?'}`\n\n  );\n\n  if (mainOnly) return { player, context: {} as HooksCtx, isFallback };\n\n  let context: HooksCtx | undefined;\n\n  if (!isFallback) {\n    context = useContext(player.context);\n    if (!context)\n    throw new IllegalHookInvocationError(\n      hookName,\n      `${hookName} must be called inside a player context created by <Player>.context.provide()`\n    );\n  } else {\n    context = {\n      get guild() {\n        throw new IllegalHookInvocationError(\n          hookName,\n          `${hookName} must be called with an explicit guild argument when not inside a player context`\n        );\n      }\n    } as unknown as HooksCtx;\n  }\n\n  return { context, player, isFallback };\n}", "import { GuildQueueHistory, NodeResolvable } from '../queue';\nimport { useHooksContext } from './common';\n\n/**\n * Fetch guild queue history\n * @param node guild queue node resolvable\n */\nexport function useHistory<Meta = unknown>(): GuildQueueHistory<Meta> | null;\nexport function useHistory<Meta = unknown>(node: NodeResolvable): GuildQueueHistory<Meta> | null;\nexport function useHistory<Meta = unknown>(node?: NodeResolvable): GuildQueueHistory<Meta> | null {\n  const { context, player } = useHooksContext('useHistory');\n\n  const queue = player.queues.get<Meta>(node ?? context.guild.id);\n  if (!queue) return null;\n\n  return queue.history;\n}", "import { GuildQueuePlayerNode, NodeResolvable } from '../queue';\nimport { useHooksContext } from './common';\n\n/**\n * Fetch guild queue player node\n * @param node Guild queue node resolvable\n */\nexport function usePlayer<Meta = unknown>(): GuildQueuePlayerNode<Meta> | null;\nexport function usePlayer<Meta = unknown>(node: NodeResolvable): GuildQueuePlayerNode<Meta> | null;\nexport function usePlayer<Meta = unknown>(node?: NodeResolvable): GuildQueuePlayerNode<Meta> | null {\n  const { context, player } = useHooksContext('usePlayer');\n  const queue = player.queues.get<Meta>(node ?? context.guild.id);\n  if (!queue) return null;\n\n  return queue.node;\n}", "import { GuildQueue, NodeResolvable } from '../queue';\nimport { useHooksContext } from './common';\n\n/**\n * Fetch guild queue.\n * @param node Guild queue node resolvable. Defaults to inferred guild from context.\n */\nexport function useQueue<Meta = unknown>(): GuildQueue<Meta> | null;\nexport function useQueue<Meta = unknown>(node: NodeResolvable): GuildQueue<Meta> | null;\nexport function useQueue<Meta = unknown>(node?: NodeResolvable): GuildQueue<Meta> | null {\n  const { context, player } = useHooksContext('useQueue');\n  const queue = player.queues.resolve<Meta>(node ?? context.guild.id);\n  if (!queue) return null;\n\n  return queue;\n}", "import { useHooksContext } from './common';\n\n/**\n * Fetch main player instance\n */\nexport function useMainPlayer() {\n  const { player } = useHooksContext('useMainPlayer', true);\n\n  return player;\n}", "import { NodeResolvable } from '../queue';\nimport { TypeUtil } from '../utils/TypeUtil';\nimport { useHooksContext } from './common';\n\nexport type SetterFN<T, P> = (previous: P) => T;\nexport type MetadataDispatch<T> = readonly [() => T, (metadata: T | SetterFN<T, T>) => void];\n\n/**\n * Fetch or manipulate guild queue metadata\n * @param node Guild queue node resolvable\n */\nexport function useMetadata<T = unknown>(): MetadataDispatch<T>;\nexport function useMetadata<T = unknown>(node: NodeResolvable): MetadataDispatch<T>;\nexport function useMetadata<T = unknown>(node?: NodeResolvable): MetadataDispatch<T> {\n  const { context, player } = useHooksContext('useMetadata');\n  const queue = player.queues.get<T>(node ?? context.guild.id);\n  const setter = (metadata: T | SetterFN<T, T>) => {\n    if (queue) {\n      if (TypeUtil.isFunction(metadata)) return queue.setMetadata(metadata(queue.metadata));\n      return queue.setMetadata(metadata);\n    }\n  };\n\n  const getter = () => {\n    return queue?.metadata as T;\n  };\n\n  return [getter, setter] as const;\n}", "import { Track } from '../fabric';\nimport { NodeResolvable, PlayerTimestamp } from '../queue';\nimport { useHooksContext } from './common';\n\nexport interface TimelineDispatcherOptions {\n  ignoreFilters: boolean;\n  node: NodeResolvable;\n}\n\nexport interface GuildQueueTimeline {\n  readonly timestamp: PlayerTimestamp;\n  readonly volume: number;\n  readonly paused: boolean;\n  readonly track: Track<unknown> | null;\n  pause(): boolean;\n  resume(): boolean;\n  setVolume(vol: number): boolean;\n  setPosition(time: number): Promise<boolean>;\n}\n\n/**\n * Fetch or manipulate current track\n * @param options Options for timeline dispatcher\n */\nexport function useTimeline(): GuildQueueTimeline | null;\nexport function useTimeline(options: Partial<TimelineDispatcherOptions>): GuildQueueTimeline | null;\nexport function useTimeline(options?: Partial<TimelineDispatcherOptions>): GuildQueueTimeline | null {\n  const { context, player } = useHooksContext('useTimeline');\n  const queue = player.queues.get(options?.node ?? context.guild.id);\n  if (!queue) return null;\n\n  const timeline = Object.preventExtensions({\n    get timestamp() {\n      return queue.node.getTimestamp(options?.ignoreFilters)!;\n    },\n    get volume() {\n      return queue.node.volume;\n    },\n    get paused() {\n      return queue.node.isPaused();\n    },\n    get track() {\n      return queue.currentTrack;\n    },\n    pause() {\n      return queue.node.pause();\n    },\n    resume() {\n      return queue.node.resume();\n    },\n    setVolume(vol: number) {\n      return queue.node.setVolume(vol);\n    },\n    async setPosition(time: number) {\n      return queue.node.seek(time);\n    }\n  });\n\n  return timeline;\n}", "import { OnAfterCreateStreamHandler } from '../../queue';\nimport { getGlobalRegistry } from '../../utils/__internal__';\n\n/**\n * Global onAfterCreateStream handler\n * @param handler The handler callback\n */\nexport function onAfterCreateStream(handler: OnAfterCreateStreamHandler) {\n  getGlobalRegistry().set('@[onAfterCreateStream]', handler);\n}", "import { OnBeforeCreateStreamHandler } from '../../queue';\nimport { getGlobalRegistry } from '../../utils/__internal__';\n\n/**\n * Global onBeforeCreateStream handler\n * @param handler The handler callback\n */\nexport function onBeforeCreateStream(handler: OnBeforeCreateStreamHandler) {\n  getGlobalRegistry().set('@[onBeforeCreateStream]', handler);\n}", "import { NodeResolvable } from '../queue';\nimport { TypeUtil } from '../utils/TypeUtil';\nimport { useHooksContext } from './common';\n\ntype SetterFN = (previous: number) => number;\ntype VolumeDispatch = readonly [() => number, (volume: number | SetterFN) => boolean | undefined];\n\n/**\n * Fetch or manipulate player volume\n * @param node Guild queue node resolvable\n */\nexport function useVolume(): VolumeDispatch;\nexport function useVolume(node: NodeResolvable): VolumeDispatch;\nexport function useVolume(node?: NodeResolvable): VolumeDispatch {\n  const { context, player } = useHooksContext('useVolume');\n  const queue = player.queues.get(node ?? context.guild.id);\n  const setter = (volume: number | SetterFN) => {\n    if (queue) {\n      if (TypeUtil.isFunction(volume)) return queue.node.setVolume(volume(queue.node.volume));\n      return queue.node.setVolume(volume);\n    }\n  };\n\n  const getter = () => {\n    return queue?.node.volume as number;\n  };\n\n  return [getter, setter] as const;\n}", "import { EqualizerBand, PCMFilters, BiquadFilters } from '@discord-player/equalizer';\nimport { Collection, QueueStrategy } from '@discord-player/utils';\nimport { GuildResolvable } from 'discord.js';\nimport { Player } from '../Player';\nimport { GuildQueue, OnAfterCreateStreamHandler, OnBeforeCreateStreamHandler, QueueRepeatMode } from './GuildQueue';\nimport { getGlobalRegistry } from '../utils/__internal__';\nimport { NoGuildError, NoGuildQueueError } from '../errors';\nimport { FiltersName } from '../fabric';\n\nexport interface GuildNodeCreateOptions<T = unknown> {\n  strategy?: QueueStrategy;\n  volume?: number;\n  equalizer?: EqualizerBand[];\n  a_filter?: PCMFilters[];\n  biquad?: BiquadFilters;\n  resampler?: number;\n  disableHistory?: boolean;\n  onBeforeCreateStream?: OnBeforeCreateStreamHandler;\n  onAfterCreateStream?: OnAfterCreateStreamHandler;\n  repeatMode?: QueueRepeatMode;\n  pauseOnEmpty?: boolean;\n  leaveOnEmpty?: boolean;\n  leaveOnEmptyCooldown?: number;\n  leaveOnEnd?: boolean;\n  leaveOnEndCooldown?: number;\n  leaveOnStop?: boolean;\n  leaveOnStopCooldown?: number;\n  metadata?: T | null;\n  selfDeaf?: boolean;\n  connectionTimeout?: number;\n  defaultFFmpegFilters?: FiltersName[];\n  bufferingTimeout?: number;\n  noEmitInsert?: boolean;\n  maxSize?: number;\n  maxHistorySize?: number;\n  preferBridgedMetadata?: boolean;\n  disableVolume?: boolean;\n  disableEqualizer?: boolean;\n  disableFilterer?: boolean;\n  disableBiquad?: boolean;\n  disableResampler?: boolean;\n  disableFallbackStream?: boolean;\n}\n\nexport type NodeResolvable = GuildQueue | GuildResolvable;\n\nexport class GuildNodeManager<Meta = unknown> {\n  public cache = new Collection<string, GuildQueue>();\n  public constructor(public player: Player) {}\n\n  /**\n   * Create guild queue if it does not exist\n   * @param guild The guild which will be the owner of the queue\n   * @param options Queue initializer options\n   */\n  public create<T = Meta>(guild: GuildResolvable, options: GuildNodeCreateOptions<T> = {}): GuildQueue<T> {\n    const server = this.player.client.guilds.resolve(guild);\n    if (!server) {\n      throw new NoGuildError('Invalid or unknown guild');\n    }\n\n    if (this.cache.has(server.id)) {\n      return this.cache.get(server.id) as GuildQueue<T>;\n    }\n\n    options.strategy ??= 'FIFO';\n    options.volume ??= 100;\n    options.equalizer ??= [];\n    options.a_filter ??= [];\n    options.disableHistory ??= false;\n    options.leaveOnEmpty ??= true;\n    options.leaveOnEmptyCooldown ??= 0;\n    options.leaveOnEnd ??= true;\n    options.leaveOnEndCooldown ??= 0;\n    options.leaveOnStop ??= true;\n    options.leaveOnStopCooldown ??= 0;\n    options.resampler ??= 48000;\n    options.selfDeaf ??= true;\n    options.connectionTimeout ??= this.player.options.connectionTimeout;\n    options.bufferingTimeout ??= 1000;\n    options.maxSize ??= Infinity;\n    options.maxHistorySize ??= Infinity;\n    options.preferBridgedMetadata ??= true;\n    options.pauseOnEmpty ??= true;\n    // todo(twlite): maybe disable these by default?\n    options.disableBiquad ??= false;\n    options.disableEqualizer ??= false;\n    options.disableFilterer ??= false;\n    options.disableVolume ??= false;\n    options.disableResampler ??= true;\n    options.disableFallbackStream ??= false;\n\n    if (getGlobalRegistry().has('@[onBeforeCreateStream]') && !options.onBeforeCreateStream) {\n      options.onBeforeCreateStream = getGlobalRegistry().get('@[onBeforeCreateStream]') as OnBeforeCreateStreamHandler;\n    }\n\n    if (getGlobalRegistry().has('@[onAfterCreateStream]') && !options.onAfterCreateStream) {\n      options.onAfterCreateStream = getGlobalRegistry().get('@[onAfterCreateStream]') as OnAfterCreateStreamHandler;\n    }\n\n    const queue = new GuildQueue<T>(this.player, {\n      guild: server,\n      queueStrategy: options.strategy,\n      volume: options.volume,\n      equalizer: options.equalizer,\n      filterer: options.a_filter,\n      biquad: options.biquad,\n      resampler: options.resampler,\n      disableHistory: options.disableHistory,\n      onBeforeCreateStream: options.onBeforeCreateStream,\n      onAfterCreateStream: options.onAfterCreateStream,\n      repeatMode: options.repeatMode,\n      leaveOnEmpty: options.leaveOnEmpty,\n      leaveOnEmptyCooldown: options.leaveOnEmptyCooldown,\n      leaveOnEnd: options.leaveOnEnd,\n      leaveOnEndCooldown: options.leaveOnEndCooldown,\n      leaveOnStop: options.leaveOnStop,\n      leaveOnStopCooldown: options.leaveOnStopCooldown,\n      metadata: options.metadata,\n      connectionTimeout: options.connectionTimeout ?? 120_000,\n      selfDeaf: options.selfDeaf,\n      ffmpegFilters: options.defaultFFmpegFilters ?? [],\n      bufferingTimeout: options.bufferingTimeout,\n      noEmitInsert: options.noEmitInsert ?? false,\n      preferBridgedMetadata: options.preferBridgedMetadata,\n      maxHistorySize: options.maxHistorySize,\n      maxSize: options.maxSize,\n      pauseOnEmpty: options.pauseOnEmpty,\n      disableBiquad: options.disableBiquad,\n      disableEqualizer: options.disableEqualizer,\n      disableFilterer: options.disableFilterer,\n      disableResampler: options.disableResampler,\n      disableVolume: options.disableVolume,\n      disableFallbackStream: options.disableFallbackStream\n    });\n\n    this.cache.set(server.id, queue);\n\n    return queue;\n  }\n\n  /**\n   * Get existing queue\n   * @param node Queue resolvable\n   */\n  public get<T = Meta>(node: NodeResolvable) {\n    const queue = this.resolve(node);\n    if (!queue) return null;\n\n    return this.cache.get(queue.id) as GuildQueue<T> || null;\n  }\n\n  /**\n   * Check if a queue exists\n   * @param node Queue resolvable\n   */\n  public has(node: NodeResolvable) {\n    const id = node instanceof GuildQueue ? node.id : this.player.client.guilds.resolveId(node)!;\n    return this.cache.has(id);\n  }\n\n  /**\n   * Delete queue\n   * @param node Queue resolvable\n   */\n  public delete(node: NodeResolvable) {\n    const queue = this.resolve(node);\n    if (!queue) {\n      throw new NoGuildQueueError('Cannot delete non-existing queue');\n    }\n\n    queue.setTransitioning(true);\n    queue.node.stop(true);\n    // @ts-ignore\n    queue.connection?.removeAllListeners();\n    queue.dispatcher?.removeAllListeners();\n    queue.dispatcher?.disconnect();\n    queue.timeouts.forEach((tm) => clearTimeout(tm));\n    queue.history.clear();\n    queue.tracks.clear();\n\n    return this.cache.delete(queue.id);\n  }\n\n  /**\n   * Resolve queue\n   * @param node Queue resolvable\n   */\n  public resolve<T = Meta>(node: NodeResolvable): GuildQueue<T> | undefined {\n    if (node instanceof GuildQueue) {\n      return node as GuildQueue<T>;\n    }\n\n    return this.cache.get(this.player.client.guilds.resolveId(node)!) as GuildQueue<T>;\n  }\n\n  /**\n   * Resolve queue id\n   * @param node Queue resolvable\n   */\n  public resolveId(node: NodeResolvable) {\n    const q = this.resolve(node);\n    return q?.id || null;\n  }\n}", "import { Player, PlayerNodeInitializerOptions, TrackLike } from '../Player';\nimport { ChannelType, Guild, GuildVoiceChannelResolvable, VoiceBasedChannel, VoiceState } from 'discord.js';\nimport { Collection, Queue, QueueStrategy } from '@discord-player/utils';\nimport { BiquadFilters, EqualizerBand, PCMFilters } from '@discord-player/equalizer';\nimport { Track, TrackResolvable } from '../fabric/Track';\nimport { StreamDispatcher } from '../stream/StreamDispatcher';\nimport { type AudioPlayer, AudioResource, StreamType, VoiceConnection, VoiceConnectionStatus } from 'discord-voip';\nimport { Util, VALIDATE_QUEUE_CAP } from '../utils/Util';\nimport { Playlist } from '../fabric/Playlist';\nimport { GuildQueueHistory } from './GuildQueueHistory';\nimport { GuildQueuePlayerNode, StreamConfig } from './GuildQueuePlayerNode';\nimport { GuildQueueAudioFilters } from './GuildQueueAudioFilters';\nimport { Readable } from 'stream';\nimport { setTimeout } from 'timers';\nimport { GuildQueueStatistics } from './GuildQueueStatistics';\nimport { TypeUtil } from '../utils/TypeUtil';\nimport { AsyncQueue } from '../utils/AsyncQueue';\nimport {\n  InvalidArgTypeError,\n  NoVoiceChannelError,\n  NoVoiceConnectionError,\n  VoiceConnectionDestroyedError } from\n'../errors';\nimport { SyncedLyricsProvider } from './SyncedLyricsProvider';\nimport { LrcGetResult, LrcSearchResult } from '../lrclib/LrcLib';\nimport { FiltersName } from '../fabric';\nimport { SearchQueryType } from '../utils/QueryResolver';\n\nexport interface GuildNodeInit<Meta = unknown> {\n  guild: Guild;\n  queueStrategy: QueueStrategy;\n  equalizer: EqualizerBand[] | boolean;\n  volume: number | boolean;\n  biquad: BiquadFilters | boolean | undefined;\n  resampler: number | boolean;\n  filterer: PCMFilters[] | boolean;\n  ffmpegFilters: FiltersName[];\n  disableHistory: boolean;\n  onBeforeCreateStream?: OnBeforeCreateStreamHandler;\n  onAfterCreateStream?: OnAfterCreateStreamHandler;\n  repeatMode?: QueueRepeatMode;\n  leaveOnEmpty: boolean;\n  leaveOnEmptyCooldown: number;\n  leaveOnEnd: boolean;\n  leaveOnEndCooldown: number;\n  leaveOnStop: boolean;\n  leaveOnStopCooldown: number;\n  connectionTimeout: number;\n  selfDeaf?: boolean;\n  metadata?: Meta | null;\n  bufferingTimeout: number;\n  noEmitInsert: boolean;\n  maxSize?: number;\n  maxHistorySize?: number;\n  preferBridgedMetadata: boolean;\n  pauseOnEmpty?: boolean;\n  disableVolume: boolean;\n  disableEqualizer: boolean;\n  disableFilterer: boolean;\n  disableBiquad: boolean;\n  disableResampler: boolean;\n  disableFallbackStream: boolean;\n}\n\nexport interface VoiceConnectConfig {\n  deaf?: boolean;\n  timeout?: number;\n  group?: string;\n  audioPlayer?: AudioPlayer;\n}\n\nexport interface PostProcessedResult {\n  stream: Readable;\n  type: StreamType;\n}\n\nexport type OnBeforeCreateStreamHandler = (\ntrack: Track,\nqueryType: SearchQueryType,\nqueue: GuildQueue)\n=> Promise<Readable | null>;\nexport type OnAfterCreateStreamHandler = (stream: Readable, queue: GuildQueue) => Promise<PostProcessedResult | null>;\n\nexport type PlayerTriggeredReason = 'filters' | 'normal';\n\nexport const GuildQueueEvent = {\n  /**\n   * Emitted when audio track is added to the queue\n   */\n  AudioTrackAdd: 'audioTrackAdd',\n  /**\n   * Emitted when audio tracks were added to the queue\n   */\n  AudioTracksAdd: 'audioTracksAdd',\n  /**\n   * Emitted when audio track is removed from the queue\n   */\n  AudioTrackRemove: 'audioTrackRemove',\n  /**\n   * Emitted when audio tracks are removed from the queue\n   */\n  AudioTracksRemove: 'audioTracksRemove',\n  /**\n   * Emitted when a connection is created\n   */\n  Connection: 'connection',\n  /**\n   * Emitted when a voice connection is destroyed\n   */\n  ConnectionDestroyed: 'connectionDestroyed',\n  /**\n   * Emitted when the bot is disconnected from the channel\n   */\n  Disconnect: 'disconnect',\n  /**\n   * Emitted when the queue sends a debug info\n   */\n  Debug: 'debug',\n  /**\n   * Emitted when the queue encounters error\n   */\n  Error: 'error',\n  /**\n   * Emitted when the voice channel is empty\n   */\n  EmptyChannel: 'emptyChannel',\n  /**\n   * Emitted when the queue is empty\n   */\n  EmptyQueue: 'emptyQueue',\n  /**\n   * Emitted when the audio player starts streaming audio track\n   */\n  PlayerStart: 'playerStart',\n  /**\n   * Emitted when the audio player errors while streaming audio track\n   */\n  PlayerError: 'playerError',\n  /**\n   * Emitted when the audio player finishes streaming audio track\n   */\n  PlayerFinish: 'playerFinish',\n  /**\n   * Emitted when the audio player skips current track\n   */\n  PlayerSkip: 'playerSkip',\n  /**\n   * Emitted when the audio player is triggered\n   */\n  PlayerTrigger: 'playerTrigger',\n  /**\n   * Emitted when the voice state is updated. Consuming this event may disable default voice state update handler if `Player.isVoiceStateHandlerLocked()` returns `false`.\n   */\n  VoiceStateUpdate: 'voiceStateUpdate',\n  /**\n   * Emitted when volume is updated\n   */\n  VolumeChange: 'volumeChange',\n  /**\n   * Emitted when player is paused\n   */\n  PlayerPause: 'playerPause',\n  /**\n   * Emitted when player is resumed\n   */\n  PlayerResume: 'playerResume',\n  /**\n   * Biquad Filters Update\n   */\n  BiquadFiltersUpdate: 'biquadFiltersUpdate',\n  /**\n   * Equalizer Update\n   */\n  EqualizerUpdate: 'equalizerUpdate',\n  /**\n   * DSP update\n   */\n  DSPUpdate: 'dspUpdate',\n  /**\n   * Audio Filters Update\n   */\n  AudioFiltersUpdate: 'audioFiltersUpdate',\n  /**\n   * Audio player will play next track\n   */\n  WillPlayTrack: 'willPlayTrack',\n  /**\n   * Emitted when a voice channel is repopulated\n   */\n  ChannelPopulate: 'channelPopulate',\n  /**\n   * Emitted when a queue is successfully created\n   */\n  QueueCreate: 'queueCreate',\n  /**\n   * Emitted when a queue is deleted\n   */\n  QueueDelete: 'queueDelete',\n  /**\n   * Emitted when a queue is trying to add similar track for autoplay\n   */\n  WillAutoPlay: 'willAutoPlay'\n} as const;\n\nexport type GuildQueueEvent = (typeof GuildQueueEvent)[keyof typeof GuildQueueEvent];\n\nexport enum TrackSkipReason {\n  NoStream = 'ERR_NO_STREAM',\n  Manual = 'MANUAL',\n  SEEK_OVER_THRESHOLD = 'SEEK_OVER_THRESHOLD',\n  Jump = 'JUMPED_TO_ANOTHER_TRACK',\n  SkipTo = 'SKIP_TO_ANOTHER_TRACK',\n  HistoryNext = 'HISTORY_NEXT_TRACK',\n}\n\n// eslint-disable-next-line @typescript-eslint/no-explicit-any\nexport interface GuildQueueEvents<Meta = any> {\n  /**\n   * Emitted when audio track is added to the queue\n   * @param queue The queue where this event occurred\n   * @param track The track\n   */\n  [GuildQueueEvent.AudioTrackAdd]: (queue: GuildQueue<Meta>, track: Track) => unknown;\n  /**\n   * Emitted when audio tracks were added to the queue\n   * @param queue The queue where this event occurred\n   * @param tracks The tracks array\n   */\n  [GuildQueueEvent.AudioTracksAdd]: (queue: GuildQueue<Meta>, track: Track[]) => unknown;\n  /**\n   * Emitted when audio track is removed from the queue\n   * @param queue The queue where this event occurred\n   * @param track The track\n   */\n  [GuildQueueEvent.AudioTrackRemove]: (queue: GuildQueue<Meta>, track: Track) => unknown;\n  /**\n   * Emitted when audio tracks are removed from the queue\n   * @param queue The queue where this event occurred\n   * @param track The track\n   */\n  [GuildQueueEvent.AudioTracksRemove]: (queue: GuildQueue<Meta>, track: Track[]) => unknown;\n  /**\n   * Emitted when a connection is created\n   * @param queue The queue where this event occurred\n   */\n  [GuildQueueEvent.Connection]: (queue: GuildQueue<Meta>) => unknown;\n  /**\n   * Emitted when a connection is destroyed\n   * @param queue The queue where this event occurred\n   */\n  [GuildQueueEvent.ConnectionDestroyed]: (queue: GuildQueue<Meta>) => unknown;\n  /**\n   * Emitted when the bot is disconnected from the channel\n   * @param queue The queue where this event occurred\n   */\n  [GuildQueueEvent.Disconnect]: (queue: GuildQueue<Meta>) => unknown;\n  /**\n   * Emitted when the queue sends a debug info\n   * @param queue The queue where this event occurred\n   * @param message The debug message\n   */\n  [GuildQueueEvent.Debug]: (queue: GuildQueue<Meta>, message: string) => unknown;\n  /**\n   * Emitted when the queue encounters error\n   * @param queue The queue where this event occurred\n   * @param error The error\n   */\n  [GuildQueueEvent.Error]: (queue: GuildQueue<Meta>, error: Error) => unknown;\n  /**\n   * Emitted when the voice channel is empty\n   * @param queue The queue where this event occurred\n   */\n  [GuildQueueEvent.EmptyChannel]: (queue: GuildQueue<Meta>) => unknown;\n  /**\n   * Emitted when the queue is empty\n   * @param queue The queue where this event occurred\n   */\n  [GuildQueueEvent.EmptyQueue]: (queue: GuildQueue<Meta>) => unknown;\n  /**\n   * Emitted when the audio player starts streaming audio track\n   * @param queue The queue where this event occurred\n   * @param track The track that is being streamed\n   */\n  [GuildQueueEvent.PlayerStart]: (queue: GuildQueue<Meta>, track: Track) => unknown;\n  /**\n   * Emitted when the audio player errors while streaming audio track\n   * @param queue The queue where this event occurred\n   * @param error The error\n   * @param track The track that is being streamed\n   */\n  [GuildQueueEvent.PlayerError]: (queue: GuildQueue<Meta>, error: Error, track: Track) => unknown;\n  /**\n   * Emitted when the audio player finishes streaming audio track\n   * @param queue The queue where this event occurred\n   * @param track The track that was being streamed\n   */\n  [GuildQueueEvent.PlayerFinish]: (queue: GuildQueue<Meta>, track: Track) => unknown;\n  /**\n   * Emitted when the audio player skips current track\n   * @param queue The queue where this event occurred\n   * @param track The track that was skipped\n   * @param reason The reason for skipping\n   * @param description The description for skipping\n   */\n  [GuildQueueEvent.PlayerSkip]: (\n  queue: GuildQueue<Meta>,\n  track: Track,\n  reason: TrackSkipReason,\n  description: string)\n  => unknown;\n  /**\n   * Emitted when the audio player is triggered\n   * @param queue The queue where this event occurred\n   * @param track The track which was played in this event\n   */\n  [GuildQueueEvent.PlayerTrigger]: (queue: GuildQueue<Meta>, track: Track, reason: PlayerTriggeredReason) => unknown;\n  /**\n   * Emitted when the voice state is updated. Consuming this event may disable default voice state update handler if `Player.isVoiceStateHandlerLocked()` returns `false`.\n   * @param queue The queue where this event occurred\n   * @param oldState The old voice state\n   * @param newState The new voice state\n   */\n  [GuildQueueEvent.VoiceStateUpdate]: (queue: GuildQueue<Meta>, oldState: VoiceState, newState: VoiceState) => unknown;\n  /**\n   * Emitted when audio player is paused\n   * @param queue The queue where this event occurred\n   */\n  [GuildQueueEvent.PlayerPause]: (queue: GuildQueue<Meta>) => unknown;\n  /**\n   * Emitted when audio player is resumed\n   * @param queue The queue where this event occurred\n   */\n  [GuildQueueEvent.PlayerResume]: (queue: GuildQueue<Meta>) => unknown;\n  /**\n   * Emitted when audio player's volume is changed\n   * @param queue The queue where this event occurred\n   * @param oldVolume The old volume\n   * @param newVolume The updated volume\n   */\n  [GuildQueueEvent.VolumeChange]: (queue: GuildQueue<Meta>, oldVolume: number, newVolume: number) => unknown;\n  /**\n   * Emitted when equalizer config is updated\n   * @param queue The queue where this event occurred\n   * @param oldFilters Old filters\n   * @param newFilters New filters\n   */\n  [GuildQueueEvent.EqualizerUpdate]: (\n  queue: GuildQueue<Meta>,\n  oldFilters: EqualizerBand[],\n  newFilters: EqualizerBand[])\n  => unknown;\n  /**\n   * Emitted when biquad filters is updated\n   * @param queue The queue where this event occurred\n   * @param oldFilters Old filters\n   * @param newFilters New filters\n   */\n  [GuildQueueEvent.BiquadFiltersUpdate]: (\n  queue: GuildQueue<Meta>,\n  oldFilters: BiquadFilters | null,\n  newFilters: BiquadFilters | null)\n  => unknown;\n  /**\n   * Emitted when dsp filters is updated\n   * @param queue The queue where this event occurred\n   * @param oldFilters Old filters\n   * @param newFilters New filters\n   */\n  [GuildQueueEvent.DSPUpdate]: (queue: GuildQueue<Meta>, oldFilters: PCMFilters[], newFilters: PCMFilters[]) => unknown;\n  /**\n   * Emitted when ffmpeg audio filters is updated\n   * @param queue The queue where this event occurred\n   * @param oldFilters Old filters\n   * @param newFilters New filters\n   */\n  [GuildQueueEvent.AudioFiltersUpdate]: (\n  queue: GuildQueue<Meta>,\n  oldFilters: FiltersName[],\n  newFilters: FiltersName[])\n  => unknown;\n\n  /**\n   * Emitted before streaming an audio track. This event can be used to modify stream config before playing a track.\n   * Listening to this event will pause the execution of audio player until `done()` is invoked.\n   * @param queue The queue where this event occurred\n   * @param track The track that will be streamed\n   * @param config Configurations for streaming\n   * @param done Done callback\n   */\n  [GuildQueueEvent.WillPlayTrack]: (\n  queue: GuildQueue<Meta>,\n  track: Track<unknown>,\n  config: StreamConfig,\n  done: () => void)\n  => unknown;\n  /**\n   * Emitted when a voice channel is populated\n   * @param queue The queue where this event occurred\n   */\n  [GuildQueueEvent.ChannelPopulate]: (queue: GuildQueue<Meta>) => unknown;\n  /**\n   * Emitted when a queue is successfully created\n   * @param queue The queue where this event occurred\n   */\n  [GuildQueueEvent.QueueCreate]: (queue: GuildQueue<Meta>) => unknown;\n  /**\n   * Emitted when a queue is successfully deleted\n   * @param queue The queue where this event occurred\n   */\n  [GuildQueueEvent.QueueDelete]: (queue: GuildQueue<Meta>) => unknown;\n  /**\n   * Emitted when a queue is trying to add similar track for autoplay\n   * @param queue The queue where this event occurred\n   * @param tracks The similar tracks that were found\n   * @param done Done callback\n   */\n  [GuildQueueEvent.WillAutoPlay]: (\n  queue: GuildQueue<Meta>,\n  tracks: Track[],\n  done: (track: Track | null) => void)\n  => unknown;\n}\n\n/**\n * The queue repeat mode. This can be one of:\n * - OFF\n * - TRACK\n * - QUEUE\n * - AUTOPLAY\n */\nexport const QueueRepeatMode = {\n  /**\n   * Disable repeat mode.\n   */\n  OFF: 0,\n  /**\n   * Repeat the current track.\n   */\n  TRACK: 1,\n  /**\n   * Repeat the entire queue.\n   */\n  QUEUE: 2,\n  /**\n   * When last track ends, play similar tracks in the future if queue is empty.\n   */\n  AUTOPLAY: 3\n} as const;\n\nexport type QueueRepeatMode = (typeof QueueRepeatMode)[keyof typeof QueueRepeatMode];\n\nexport class GuildQueue<Meta = unknown> {\n  #transitioning = false;\n  #deleted = false;\n  #shuffle = false;\n  private __current: Track | null = null;\n  public tracks: Queue<Track>;\n  public history = new GuildQueueHistory<Meta>(this);\n  public dispatcher: StreamDispatcher | null = null;\n  public node = new GuildQueuePlayerNode<Meta>(this);\n  public filters = new GuildQueueAudioFilters<Meta>(this);\n  public onBeforeCreateStream: OnBeforeCreateStreamHandler = async () => null;\n  public onAfterCreateStream: OnAfterCreateStreamHandler = async (stream) => ({\n    stream,\n    type: StreamType.Raw\n  });\n  public repeatMode: QueueRepeatMode = QueueRepeatMode.OFF;\n  public timeouts = new Collection<string, NodeJS.Timeout>();\n  public stats = new GuildQueueStatistics<Meta>(this);\n  public tasksQueue = new AsyncQueue();\n  public syncedLyricsProvider = new SyncedLyricsProvider(this);\n\n  public constructor(public player: Player, public options: GuildNodeInit<Meta>) {\n    this.tracks = new Queue<Track>(options.queueStrategy);\n    if (TypeUtil.isFunction(options.onBeforeCreateStream)) this.onBeforeCreateStream = options.onBeforeCreateStream;\n    if (TypeUtil.isFunction(options.onAfterCreateStream)) this.onAfterCreateStream = options.onAfterCreateStream;\n    if (!TypeUtil.isNullish(options.repeatMode)) this.repeatMode = options.repeatMode;\n\n    options.selfDeaf ??= true;\n    options.maxSize ??= Infinity;\n    options.maxHistorySize ??= Infinity;\n    options.pauseOnEmpty ??= true;\n\n    if (!TypeUtil.isNullish(this.options.biquad) && !TypeUtil.isBoolean(this.options.biquad)) {\n      this.filters._lastFiltersCache.biquad = this.options.biquad;\n    }\n\n    if (Array.isArray(this.options.equalizer)) {\n      this.filters._lastFiltersCache.equalizer = this.options.equalizer;\n    }\n\n    if (Array.isArray(this.options.filterer)) {\n      this.filters._lastFiltersCache.filters = this.options.filterer;\n    }\n\n    if (TypeUtil.isNumber(this.options.resampler)) {\n      this.filters._lastFiltersCache.sampleRate = this.options.resampler;\n    }\n\n    if (TypeUtil.isArray(this.options.ffmpegFilters)) {\n      this.filters.ffmpeg.setDefaults(this.options.ffmpegFilters);\n    }\n\n    if (!TypeUtil.isNumber(options.maxSize)) {\n      throw new InvalidArgTypeError('[GuildNodeInit.maxSize]', 'number', typeof options.maxSize);\n    }\n\n    if (!TypeUtil.isNumber(options.maxHistorySize)) {\n      throw new InvalidArgTypeError('[GuildNodeInit.maxHistorySize]', 'number', typeof options.maxHistorySize);\n    }\n\n    if (options.maxSize < 1) options.maxSize = Infinity;\n    if (options.maxHistorySize < 1) options.maxHistorySize = Infinity;\n\n    if (this.hasDebugger)\n    this.debug(`GuildQueue initialized for guild ${this.options.guild.name} (ID: ${this.options.guild.id})`);\n    this.emit(GuildQueueEvent.QueueCreate, this);\n  }\n\n  /**\n   * Estimated duration of this queue in ms\n   */\n  public get estimatedDuration() {\n    return this.tracks.store.reduce((a, c) => a + c.durationMS, 0);\n  }\n\n  /**\n   * Formatted duration of this queue\n   */\n  public get durationFormatted() {\n    return Util.buildTimeCode(Util.parseMS(this.estimatedDuration));\n  }\n\n  /**\n   * The sync lyrics provider for this queue.\n   * @example const lyrics = await player.lyrics.search({ q: 'Alan Walker Faded' });\n   * const syncedLyrics = queue.syncedLyrics(lyrics[0]);\n   * console.log(syncedLyrics.at(10_000));\n   * // subscribe to lyrics change\n   * const unsubscribe = syncedLyrics.onChange((lyrics, timestamp) => {\n   *    console.log(lyrics, timestamp);\n   * });\n   * // unsubscribe from lyrics change\n   * unsubscribe(); // or\n   * syncedLyrics.unsubscribe();\n   */\n  public syncedLyrics(lyrics: LrcGetResult | LrcSearchResult) {\n    this.syncedLyricsProvider.load(lyrics?.syncedLyrics ?? '');\n    return this.syncedLyricsProvider;\n  }\n\n  /**\n   * Write a debug message to this queue\n   * @param m The message to write\n   */\n  public debug(m: string) {\n    this.emit(GuildQueueEvent.Debug, this, m);\n  }\n\n  /**\n   * The metadata of this queue\n   */\n  public get metadata() {\n    return this.options.metadata!;\n  }\n\n  public set metadata(m: Meta) {\n    this.options.metadata = m;\n  }\n\n  /**\n   * Set metadata for this queue\n   * @param m Metadata to set\n   */\n  public setMetadata(m: Meta) {\n    this.options.metadata = m;\n  }\n\n  /**\n   * Indicates current track of this queue\n   */\n  public get currentTrack() {\n    return this.dispatcher?.audioResource?.metadata || this.__current;\n  }\n\n  /**\n   * Indicates if this queue was deleted previously\n   */\n  public get deleted() {\n    return this.#deleted;\n  }\n\n  /**\n   * The voice channel of this queue\n   */\n  public get channel() {\n    return this.dispatcher?.channel || null;\n  }\n\n  public set channel(c: VoiceBasedChannel | null) {\n    if (this.dispatcher) {\n      if (c) {\n        this.dispatcher.channel = c;\n      } else {\n        this.delete();\n      }\n    }\n  }\n\n  /**\n   * The voice connection of this queue\n   */\n  public get connection() {\n    return this.dispatcher?.voiceConnection || null;\n  }\n\n  /**\n   * The guild this queue belongs to\n   */\n  public get guild() {\n    return this.options.guild;\n  }\n\n  /**\n   * The id of this queue\n   */\n  public get id() {\n    return this.guild.id;\n  }\n\n  /**\n   * Set transition mode for this queue\n   * @param state The state to set\n   */\n  public setTransitioning(state: boolean) {\n    this.#transitioning = state;\n  }\n\n  /**\n   * if this queue is currently under transition mode\n   */\n  public isTransitioning() {\n    return this.#transitioning;\n  }\n\n  /**\n   * Set repeat mode for this queue\n   * @param mode The repeat mode to apply\n   */\n  public setRepeatMode(mode: QueueRepeatMode) {\n    this.repeatMode = mode;\n  }\n\n  /**\n   * Max size of this queue\n   */\n  public get maxSize() {\n    return this.options.maxSize ?? Infinity;\n  }\n\n  /**\n   * Max size of this queue\n   */\n  public getMaxSize() {\n    return this.maxSize;\n  }\n\n  /**\n   * Gets the size of the queue\n   */\n  public get size() {\n    return this.tracks.size;\n  }\n\n  /**\n   * The size of this queue\n   */\n  public getSize() {\n    return this.size;\n  }\n\n  /**\n   * Max history size of this queue\n   */\n  public get maxHistorySize() {\n    return this.options.maxHistorySize ?? Infinity;\n  }\n\n  /**\n   * Max history size of this queue\n   */\n  public getMaxHistorySize() {\n    return this.maxHistorySize;\n  }\n\n  /**\n   * Set max history size for this queue\n   * @param size The size to set\n   */\n  public setMaxHistorySize(size: number) {\n    if (!TypeUtil.isNumber(size)) {\n      throw new InvalidArgTypeError('size', 'number', typeof size);\n    }\n\n    if (size < 1) size = Infinity;\n\n    this.options.maxHistorySize = size;\n  }\n\n  /**\n   * Set max size for this queue\n   * @param size The size to set\n   */\n  public setMaxSize(size: number) {\n    if (!TypeUtil.isNumber(size)) {\n      throw new InvalidArgTypeError('size', 'number', typeof size);\n    }\n\n    if (size < 1) size = Infinity;\n\n    this.options.maxSize = size;\n  }\n\n  /**\n   * Clear this queue\n   */\n  public clear() {\n    this.tracks.clear();\n    this.history.clear();\n  }\n\n  /**\n   * Check if this queue has no tracks left in it\n   */\n  public isEmpty() {\n    return this.tracks.size < 1;\n  }\n\n  /**\n   * Check if this queue is full\n   */\n  public isFull() {\n    return this.tracks.size >= this.maxSize;\n  }\n\n  /**\n   * Get queue capacity\n   */\n  public getCapacity() {\n    if (this.isFull()) return 0;\n    const cap = this.maxSize - this.size;\n    return cap;\n  }\n\n  /**\n   * Check if this queue currently holds active audio resource\n   */\n  public isPlaying() {\n    return this.dispatcher?.audioResource != null && !this.dispatcher.audioResource.ended;\n  }\n\n  /**\n   * Add track to the queue. This will emit `audioTracksAdd` when multiple tracks are added, otherwise `audioTrackAdd`.\n   * @param track Track or playlist or array of tracks to add\n   */\n  public addTrack(track: Track | Track[] | Playlist) {\n    const toAdd = track instanceof Playlist ? track.tracks : track;\n    const isMulti = Array.isArray(toAdd);\n\n    VALIDATE_QUEUE_CAP(this, toAdd);\n\n    this.tracks.add(toAdd);\n\n    if (isMulti) {\n      this.emit(GuildQueueEvent.AudioTracksAdd, this, toAdd);\n    } else {\n      this.emit(GuildQueueEvent.AudioTrackAdd, this, toAdd);\n    }\n  }\n\n  /**\n   * Remove a track from queue\n   * @param track The track to remove\n   */\n  public removeTrack(track: TrackResolvable) {\n    return this.node.remove(track);\n  }\n\n  /**\n   * Inserts the track to the given index\n   * @param track The track to insert\n   * @param index The index to insert the track at (defaults to 0)\n   */\n  public insertTrack(track: Track, index = 0): void {\n    return this.node.insert(track, index);\n  }\n\n  /**\n   * Moves a track in the queue\n   * @param from The track to move\n   * @param to The position to move to\n   */\n  public moveTrack(track: TrackResolvable, index = 0): void {\n    return this.node.move(track, index);\n  }\n\n  /**\n   * Copy a track in the queue\n   * @param from The track to clone\n   * @param to The position to clone at\n   */\n  public copyTrack(track: TrackResolvable, index = 0): void {\n    return this.node.copy(track, index);\n  }\n\n  /**\n   * Swap two tracks in the queue\n   * @param src The first track to swap\n   * @param dest The second track to swap\n   */\n  public swapTracks(src: TrackResolvable, dest: TrackResolvable): void {\n    return this.node.swap(src, dest);\n  }\n\n  /**\n   * Create stream dispatcher from the given connection\n   * @param connection The connection to use\n   */\n  public createDispatcher(\n  connection: VoiceConnection,\n  options: Pick<VoiceConnectConfig, 'audioPlayer' | 'timeout'> = {})\n  {\n    if (connection.state.status === VoiceConnectionStatus.Destroyed) {\n      throw new VoiceConnectionDestroyedError();\n    }\n\n    const channel = this.player.client.channels.cache.get(connection.joinConfig.channelId!);\n    if (!channel) throw new NoVoiceChannelError();\n    if (!channel.isVoiceBased())\n    throw new InvalidArgTypeError(\n      'channel',\n      `VoiceBasedChannel (type ${ChannelType.GuildVoice}/${ChannelType.GuildStageVoice})`,\n      String(channel?.type)\n    );\n\n    if (this.dispatcher) {\n      this.#removeListeners(this.dispatcher);\n      this.dispatcher.destroy();\n      this.dispatcher = null;\n    }\n\n    this.dispatcher = new StreamDispatcher(\n      connection,\n      channel,\n      this,\n      options.timeout ?? this.options.connectionTimeout,\n      options.audioPlayer\n    );\n  }\n\n  /**\n   * Connect to a voice channel\n   * @param channelResolvable The voice channel to connect to\n   * @param options Join config\n   */\n  public async connect(channelResolvable: GuildVoiceChannelResolvable, options: VoiceConnectConfig = {}) {\n    const channel = this.player.client.channels.resolve(channelResolvable);\n    if (!channel || !channel.isVoiceBased()) {\n      throw new InvalidArgTypeError(\n        'channel',\n        `VoiceBasedChannel (type ${ChannelType.GuildVoice}/${ChannelType.GuildStageVoice})`,\n        String(channel?.type)\n      );\n    }\n\n    if (this.hasDebugger)\n    this.debug(\n      `Connecting to ${channel.type === ChannelType.GuildStageVoice ? 'stage' : 'voice'} channel ${\n      channel.name} (ID: ${\n      channel.id})`\n    );\n\n    if (this.dispatcher && channel.id !== this.dispatcher.channel.id) {\n      if (this.hasDebugger) this.debug('Destroying old connection');\n      this.#removeListeners(this.dispatcher);\n      this.dispatcher.destroy();\n      this.dispatcher = null;\n    }\n\n    this.dispatcher = await this.player.voiceUtils.connect(channel, {\n      deaf: options.deaf ?? this.options.selfDeaf ?? true,\n      maxTime: options?.timeout ?? this.options.connectionTimeout ?? 120_000,\n      queue: this,\n      audioPlayer: options?.audioPlayer,\n      group: options.group ?? this.player.client.user?.id\n    });\n\n    this.emit(GuildQueueEvent.Connection, this);\n\n    if (this.channel!.type === ChannelType.GuildStageVoice) {\n      await this.channel!.guild.members.me!.voice.setSuppressed(false).catch(async () => {\n        return await this.channel!.guild.members.me!.voice.setRequestToSpeak(true).catch(Util.noop);\n      });\n    }\n\n    this.#attachListeners(this.dispatcher);\n\n    return this;\n  }\n\n  /**\n   * Enable shuffle mode for this queue\n   * @param dynamic Whether to shuffle the queue dynamically. Defaults to `true`.\n   * Dynamic shuffling will shuffle the queue when the current track ends, without mutating the queue.\n   * If set to `false`, the queue will be shuffled immediately in-place, which cannot be undone.\n   */\n  public enableShuffle(dynamic = true) {\n    if (!dynamic) {\n      this.tracks.shuffle();\n      return true;\n    }\n\n    this.#shuffle = true;\n    return true;\n  }\n\n  /**\n   * Disable shuffle mode for this queue.\n   */\n  public disableShuffle() {\n    this.#shuffle = false;\n    return true;\n  }\n\n  /**\n   * Toggle shuffle mode for this queue.\n   * @param dynamic Whether to shuffle the queue dynamically. Defaults to `true`.\n   * @returns Whether shuffle is enabled or disabled.\n   */\n  public toggleShuffle(dynamic = true) {\n    if (dynamic) {\n      this.#shuffle = !this.#shuffle;\n      return this.#shuffle;\n    } else {\n      this.tracks.shuffle();\n      return true;\n    }\n  }\n\n  /**\n   * Whether shuffle mode is enabled for this queue.\n   */\n  public get isShuffling() {\n    return this.#shuffle;\n  }\n\n  /**\n   * The voice connection latency of this queue\n   */\n  public get ping() {\n    return this.connection?.ping.udp ?? -1;\n  }\n\n  /**\n   * Delete this queue\n   */\n  public delete() {\n    if (this.player.nodes.delete(this.id)) {\n      this.#deleted = true;\n      this.player.events.emit(GuildQueueEvent.QueueDelete, this);\n      this.node.tasksQueue.cancelAll();\n      this.tasksQueue.cancelAll();\n    }\n  }\n\n  /**\n   * Revives this queue\n   * @returns\n   */\n  public revive() {\n    if (!this.deleted || this.player.nodes.has(this.id)) return;\n    this.#deleted = false;\n    this.setTransitioning(false);\n    this.player.nodes.cache.set(this.id, this);\n    this.player.events.emit(GuildQueueEvent.QueueCreate, this);\n  }\n\n  /**\n   * Set self deaf\n   * @param mode On/Off state\n   * @param reason Reason\n   */\n  public setSelfDeaf(mode?: boolean, reason?: string) {\n    return this.guild.members.me!.voice.setDeaf(mode, reason);\n  }\n\n  /**\n   * Set self mute\n   * @param mode On/Off state\n   * @param reason Reason\n   */\n  public setSelfMute(mode?: boolean, reason?: string) {\n    return this.guild.members.me!.voice.setMute(mode, reason);\n  }\n\n  /**\n   * Play a track in this queue\n   * @param track The track to be played\n   * @param options Player node initialization options\n   */\n  public async play(track: TrackLike, options?: PlayerNodeInitializerOptions<Meta>) {\n    if (!this.channel) throw new NoVoiceConnectionError();\n\n    return this.player.play(this.channel, track, options);\n  }\n\n  /**\n   * Emit an event on this queue\n   * @param event The event to emit\n   * @param args The args for the event\n   */\n  public emit<K extends keyof GuildQueueEvents<Meta>>(\n  event: K,\n  ...args: Parameters<GuildQueueEvents<Meta>[K]>)\n  : boolean {\n    if (this.deleted) return false;\n    return this.player.events.emit(event, ...args);\n  }\n\n  #attachListeners(dispatcher: StreamDispatcher) {\n    dispatcher.on('error', (e) => this.emit(GuildQueueEvent.Error, this, e));\n    dispatcher.on('debug', (m) => this.hasDebugger && this.emit(GuildQueueEvent.Debug, this, m));\n    dispatcher.on('finish', (r) => this.#performFinish(r));\n    dispatcher.on('start', (r) => this.#performStart(r));\n    dispatcher.on('destroyed', () => {\n      this.#removeListeners(dispatcher);\n      this.dispatcher = null;\n    });\n    dispatcher.on('dsp', (f) => {\n      if (!Object.is(this.filters._lastFiltersCache.filters, f)) {\n        this.emit(GuildQueueEvent.DSPUpdate, this, this.filters._lastFiltersCache.filters, f);\n      }\n      this.filters._lastFiltersCache.filters = f;\n    });\n    dispatcher.on('biquad', (f) => {\n      if (this.filters._lastFiltersCache.biquad !== f) {\n        this.emit(GuildQueueEvent.BiquadFiltersUpdate, this, this.filters._lastFiltersCache.biquad, f);\n      }\n      this.filters._lastFiltersCache.biquad = f;\n    });\n    dispatcher.on('eqBands', (f) => {\n      if (!Object.is(f, this.filters._lastFiltersCache.equalizer)) {\n        this.emit(GuildQueueEvent.EqualizerUpdate, this, this.filters._lastFiltersCache.equalizer, f);\n      }\n      this.filters._lastFiltersCache.equalizer = f;\n    });\n    dispatcher.on('volume', (f) => {\n      if (this.filters._lastFiltersCache.volume !== f)\n      this.emit(GuildQueueEvent.VolumeChange, this, this.filters._lastFiltersCache.volume, f);\n      this.filters._lastFiltersCache.volume = f;\n    });\n  }\n\n  public get hasDebugger() {\n    return this.player.events.hasDebugger;\n  }\n\n  #removeListeners<T extends {removeAllListeners: () => unknown;}>(target: T) {\n    target.removeAllListeners();\n  }\n\n  #performStart(resource?: AudioResource<Track>) {\n    const track = resource?.metadata || this.currentTrack;\n    const reason = this.isTransitioning() ? 'filters' : 'normal';\n\n    if (this.hasDebugger)\n    this.debug(\n      `Player triggered for Track ${JSON.stringify({\n        title: track?.title,\n        reason\n      })}`\n    );\n\n    this.emit(GuildQueueEvent.PlayerTrigger, this, track!, reason);\n    if (track && !this.isTransitioning()) this.emit(GuildQueueEvent.PlayerStart, this, track);\n    this.setTransitioning(false);\n  }\n\n  #getNextTrack() {\n    if (!this.isShuffling) {\n      return this.tracks.dispatch();\n    }\n\n    const store = this.tracks.store;\n\n    if (!store.length) return;\n\n    const track = Util.randomChoice(store);\n\n    this.tracks.removeOne((t) => {\n      return t.id === track.id;\n    });\n\n    return track;\n  }\n\n  #performFinish(resource?: AudioResource<Track>) {\n    const track = resource?.metadata || this.currentTrack;\n\n    if (this.hasDebugger)\n    this.debug(\n      `Track ${JSON.stringify({\n        title: track?.title,\n        isTransitionMode: this.isTransitioning()\n      })} was marked as finished`\n    );\n\n    if (!this.isTransitioning()) {\n      this.syncedLyricsProvider.unsubscribe();\n      this.syncedLyricsProvider.lyrics.clear();\n      if (this.hasDebugger)\n      this.debug('Adding track to history and emitting finish event since transition mode is disabled...');\n      if (track) {\n        this.history.push(track);\n        this.node.resetProgress();\n        this.emit(GuildQueueEvent.PlayerFinish, this, track);\n      }\n      if (this.#deleted) return this.#emitEnd();\n      if (this.tracks.size < 1 && this.repeatMode === QueueRepeatMode.OFF) {\n        if (this.hasDebugger)\n        this.debug('No more tracks left in the queue to play and repeat mode is off, initiating #emitEnd()');\n        this.#emitEnd();\n      } else {\n        if (this.repeatMode === QueueRepeatMode.TRACK) {\n          if (this.hasDebugger) this.debug('Repeat mode is set to track, repeating last track from the history...');\n          this.__current = this.history.tracks.dispatch() || track;\n          return this.node.play(this.__current!, { queue: false });\n        }\n        if (this.repeatMode === QueueRepeatMode.QUEUE) {\n          if (this.hasDebugger)\n          this.debug('Repeat mode is set to queue, moving last track from the history to current queue...');\n          const next = this.history.tracks.dispatch() || track;\n          if (next) this.tracks.add(next);\n        }\n        if (!this.tracks.size && track) {\n          if (this.repeatMode === QueueRepeatMode.AUTOPLAY) {\n            if (this.hasDebugger) this.debug('Repeat mode is set to autoplay, initiating autoplay handler...');\n            this.#handleAutoplay(track);\n            return;\n          }\n        } else {\n          if (this.hasDebugger) this.debug('Initializing next track of the queue...');\n          this.__current = this.#getNextTrack()!;\n          this.node.play(this.__current, {\n            queue: false\n          });\n        }\n      }\n    }\n  }\n\n  #emitEnd() {\n    this.__current = null;\n    this.emit(GuildQueueEvent.EmptyQueue, this);\n    if (this.options.leaveOnEnd) {\n      const tm: NodeJS.Timeout = setTimeout(() => {\n        if (this.isPlaying()) return clearTimeout(tm);\n        this.dispatcher?.disconnect();\n      }, this.options.leaveOnEndCooldown).unref();\n    }\n  }\n\n  async #handleAutoplay(track: Track) {\n    try {\n      if (this.hasDebugger)\n      this.debug(\n        `Autoplay >> Finding related tracks for Track ${track.title} (${track.url}) [ext:${\n        track.extractor?.identifier || 'N/A'}]`\n\n      );\n      const tracks =\n      (await track.extractor?.getRelatedTracks(track, this.history))?.tracks ||\n      (\n      await this.player.extractors.run(async (ext) => {\n        if (this.hasDebugger) this.debug(`Autoplay >> Querying extractor ${ext.identifier}`);\n        const res = await ext.getRelatedTracks(track, this.history);\n        if (!res.tracks.length) {\n          if (this.hasDebugger) this.debug(`Autoplay >> Extractor ${ext.identifier} failed to provide results.`);\n          return false;\n        }\n\n        if (this.hasDebugger) this.debug(`Autoplay >> Extractor ${ext.identifier} successfully returned results.`);\n\n        return res.tracks;\n      }))?.\n      result ||\n      [];\n\n      let resolver: (track: Track | null) => void = Util.noop;\n      const donePromise = new Promise<Track | null>((resolve) => resolver = resolve);\n\n      const success = this.emit(GuildQueueEvent.WillAutoPlay, this, tracks, resolver!);\n\n      // prevent dangling promise\n      if (!success) {\n        resolver(\n          tracks.length ?\n          (() => {\n            const unique = tracks.filter((tr) => !this.history.tracks.find((t) => t.url === tr.url));\n            return unique?.[0] ?? Util.randomChoice(tracks.slice(0, 5));\n          })() :\n          null\n        );\n      }\n\n      const nextTrack = await donePromise;\n\n      if (!nextTrack) {\n        if (this.hasDebugger) this.debug('Autoplay >> No track was found, initiating #emitEnd()');\n        throw 'No track was found';\n      }\n\n      await this.node.play(nextTrack, {\n        queue: false,\n        seek: 0,\n        transitionMode: false\n      });\n    } catch {\n      return this.#emitEnd();\n    }\n  }\n}", "import {\n  AudioPlayer,\n  AudioPlayerError,\n  AudioPlayerStatus,\n  AudioResource,\n  createAudioPlayer,\n  createAudioResource,\n  entersState,\n  StreamType,\n  VoiceConnection,\n  VoiceConnectionStatus,\n  VoiceConnectionDisconnectReason } from\n'discord-voip';\nimport { StageChannel, VoiceChannel } from 'discord.js';\nimport type { Readable } from 'stream';\nimport { EventEmitter } from '@discord-player/utils';\nimport { Track } from '../fabric/Track';\nimport { Util } from '../utils/Util';\nimport { EqualizerBand, BiquadFilters, PCMFilters, FiltersChain } from '@discord-player/equalizer';\nimport { GuildQueue, GuildQueueEvent, PostProcessedResult } from '../queue';\nimport { NoAudioResourceError } from '../errors';\n\nexport interface CreateStreamOps {\n  type?: StreamType;\n  // eslint-disable-next-line @typescript-eslint/no-explicit-any\n  data?: any;\n  disableVolume?: boolean;\n  disableEqualizer?: boolean;\n  disableBiquad?: boolean;\n  eq?: EqualizerBand[];\n  biquadFilter?: BiquadFilters;\n  disableFilters?: boolean;\n  defaultFilters?: PCMFilters[];\n  volume?: number;\n  disableResampler?: boolean;\n  sampleRate?: number;\n  skipFFmpeg?: boolean;\n}\n\nexport interface VoiceEvents {\n  /* eslint-disable @typescript-eslint/no-explicit-any */\n  error: (error: AudioPlayerError) => any;\n  debug: (message: string) => any;\n  start: (resource: AudioResource<Track>) => any;\n  finish: (resource: AudioResource<Track>) => any;\n  dsp: (filters: PCMFilters[]) => any;\n  eqBands: (filters: EqualizerBand[]) => any;\n  sampleRate: (filters: number) => any;\n  biquad: (filters: BiquadFilters) => any;\n  volume: (volume: number) => any;\n  destroyed: () => any;\n  /* eslint-enable @typescript-eslint/no-explicit-any */\n}\n\nclass StreamDispatcher extends EventEmitter<VoiceEvents> {\n  public voiceConnection: VoiceConnection;\n  public audioPlayer: AudioPlayer;\n  public channel: VoiceChannel | StageChannel;\n  public audioResource?: AudioResource<Track> | null;\n  public dsp = new FiltersChain();\n\n  /**\n   * Creates new connection object\n   * @param {VoiceConnection} connection The connection\n   * @param {VoiceChannel|StageChannel} channel The connected channel\n   * @private\n   */\n  constructor(\n  connection: VoiceConnection,\n  channel: VoiceChannel | StageChannel,\n  public queue: GuildQueue,\n  public readonly connectionTimeout: number = 20000,\n  audioPlayer?: AudioPlayer)\n  {\n    super();\n\n    /**\n     * The voice connection\n     * @type {VoiceConnection}\n     */\n    this.voiceConnection = connection;\n\n    /**\n     * The audio player\n     * @type {AudioPlayer}\n     */\n    this.audioPlayer =\n    audioPlayer ||\n    createAudioPlayer({\n      debug: this.queue.hasDebugger\n    });\n\n    /**\n     * The voice channel\n     * @type {VoiceChannel|StageChannel}\n     */\n    this.channel = channel;\n\n    this.voiceConnection.on('debug', (m) => void this.emit('debug', m));\n    this.voiceConnection.on('error', (error) => void this.emit('error', error as AudioPlayerError));\n    this.audioPlayer.on('debug', (m) => void this.emit('debug', m));\n    this.audioPlayer.on('error', (error) => void this.emit('error', error));\n\n    this.dsp.onUpdate = () => {\n      if (!this.dsp) return;\n      if (this.dsp.filters?.filters) this.emit('dsp', this.dsp.filters?.filters);\n      if (this.dsp.biquad?.filters) this.emit('biquad', this.dsp.biquad?.filters);\n      if (this.dsp.equalizer) this.emit('eqBands', this.dsp.equalizer.getEQ());\n      if (this.dsp.volume) this.emit('volume', this.dsp.volume.volume);\n      if (this.dsp.resampler) this.emit('sampleRate', this.dsp.resampler.targetSampleRate);\n    };\n\n    this.dsp.onError = (e) => this.emit('error', e as AudioPlayerError);\n\n    this.voiceConnection.\n    on(VoiceConnectionStatus.Disconnected, async (oldState, newState) => {\n      if (newState.reason === VoiceConnectionDisconnectReason.Manual) {\n        this.destroy();\n        return;\n      }\n\n      if (newState.reason === VoiceConnectionDisconnectReason.WebSocketClose && newState.closeCode === 4014) {\n        try {\n          await entersState(this.voiceConnection, VoiceConnectionStatus.Connecting, this.connectionTimeout);\n        } catch {\n          try {\n            if (this.voiceConnection.state.status !== VoiceConnectionStatus.Destroyed) this.destroy();\n          } catch (err) {\n            this.emit('error', err as AudioPlayerError);\n          }\n        }\n      } else if (this.voiceConnection.rejoinAttempts < 5) {\n        await Util.wait((this.voiceConnection.rejoinAttempts + 1) * 5000);\n        this.voiceConnection.rejoin();\n      } else {\n        try {\n          if (this.voiceConnection.state.status !== VoiceConnectionStatus.Destroyed) this.destroy();\n        } catch (err) {\n          this.emit('error', err as AudioPlayerError);\n        }\n      }\n    }).\n    on(VoiceConnectionStatus.Destroyed, () => {\n      this.end();\n      this.queue.emit(GuildQueueEvent.ConnectionDestroyed, this.queue);\n    });\n\n    this.audioPlayer.on('stateChange', (oldState, newState) => {\n      if (oldState.status !== AudioPlayerStatus.Paused && newState.status === AudioPlayerStatus.Paused) {\n        this.queue.emit(GuildQueueEvent.PlayerPause, this.queue);\n      }\n\n      if (oldState.status === AudioPlayerStatus.Paused && newState.status !== AudioPlayerStatus.Paused) {\n        this.queue.emit(GuildQueueEvent.PlayerResume, this.queue);\n      }\n\n      if (newState.status === AudioPlayerStatus.Playing) {\n        if (oldState.status === AudioPlayerStatus.Idle || oldState.status === AudioPlayerStatus.Buffering) {\n          return this.emit('start', this.audioResource!);\n        }\n      } else if (newState.status === AudioPlayerStatus.Idle && oldState.status !== AudioPlayerStatus.Idle) {\n        this.emit('finish', this.audioResource!);\n        this.dsp.destroy();\n        this.audioResource = null;\n      }\n    });\n\n    this.voiceConnection.subscribe(this.audioPlayer);\n  }\n\n  /**\n   * Check if the player has been paused manually\n   */\n  get paused() {\n    return this.audioPlayer.state.status === AudioPlayerStatus.Paused;\n  }\n\n  set paused(val: boolean) {\n    val ? this.pause(true) : this.resume();\n  }\n\n  /**\n   * Whether or not the player is currently paused automatically or manually.\n   */\n  isPaused() {\n    return this.paused || this.audioPlayer.state.status === AudioPlayerStatus.AutoPaused;\n  }\n\n  /**\n   * Whether or not the player is currently buffering\n   */\n  isBuffering() {\n    return this.audioPlayer.state.status === AudioPlayerStatus.Buffering;\n  }\n\n  /**\n   * Whether or not the player is currently playing\n   */\n  isPlaying() {\n    return this.audioPlayer.state.status === AudioPlayerStatus.Playing;\n  }\n\n  /**\n   * Whether or not the player is currently idle\n   */\n  isIdle() {\n    return this.audioPlayer.state.status === AudioPlayerStatus.Idle;\n  }\n\n  /**\n   * Whether or not the voice connection has been destroyed\n   */\n  isDestroyed() {\n    return this.voiceConnection.state.status === VoiceConnectionStatus.Destroyed;\n  }\n\n  /**\n   * Whether or not the voice connection has been destroyed\n   */\n  isDisconnected() {\n    return this.voiceConnection.state.status === VoiceConnectionStatus.Disconnected;\n  }\n\n  /**\n   * Whether or not the voice connection is ready to play\n   */\n  isReady() {\n    return this.voiceConnection.state.status === VoiceConnectionStatus.Ready;\n  }\n\n  /**\n   * Whether or not the voice connection is signalling\n   */\n  isSignalling() {\n    return this.voiceConnection.state.status === VoiceConnectionStatus.Signalling;\n  }\n\n  /**\n   * Whether or not the voice connection is connecting\n   */\n  isConnecting() {\n    return this.voiceConnection.state.status === VoiceConnectionStatus.Connecting;\n  }\n\n  /**\n   * Creates stream\n   * @param {Readable} src The stream source\n   * @param {object} [ops] Options\n   * @returns {AudioResource}\n   */\n  async createStream(src: Readable, ops?: CreateStreamOps) {\n    if (!ops?.disableFilters && this.queue.hasDebugger) this.queue.debug('Initiating DSP filters pipeline...');\n    const stream = !ops?.disableFilters ?\n    this.dsp.create(src, {\n      dsp: {\n        filters: ops?.defaultFilters,\n        disabled: ops?.disableFilters\n      },\n      biquad: ops?.biquadFilter ?\n      {\n        filter: ops.biquadFilter,\n        disabled: ops?.disableBiquad\n      } :\n      undefined,\n      resampler: {\n        targetSampleRate: ops?.sampleRate,\n        disabled: ops?.disableResampler\n      },\n      equalizer: {\n        bandMultiplier: ops?.eq,\n        disabled: ops?.disableEqualizer\n      },\n      volume: {\n        volume: ops?.volume,\n        disabled: ops?.disableVolume\n      }\n    }) :\n    src;\n\n    if (this.queue.hasDebugger) this.queue.debug('Executing onAfterCreateStream hook...');\n    const postStream = await this.queue.onAfterCreateStream?.(stream, this.queue).catch(\n      () =>\n      ({\n        stream: stream,\n        type: ops?.type ?? StreamType.Arbitrary\n      }) as PostProcessedResult\n    );\n\n    if (this.queue.hasDebugger) this.queue.debug('Preparing AudioResource...');\n    this.audioResource = createAudioResource(postStream?.stream ?? stream, {\n      inputType: postStream?.type ?? ops?.type ?? StreamType.Arbitrary,\n      metadata: ops?.data,\n      // volume controls happen from AudioFilter DSP utility\n      inlineVolume: false\n    });\n\n    return this.audioResource;\n  }\n\n  public get resampler() {\n    return this.dsp?.resampler;\n  }\n\n  public get filters() {\n    return this.dsp?.filters;\n  }\n\n  public get biquad() {\n    return this.dsp?.biquad || null;\n  }\n\n  public get equalizer() {\n    return this.dsp?.equalizer || null;\n  }\n\n  /**\n   * The player status\n   * @type {AudioPlayerStatus}\n   */\n  get status() {\n    return this.audioPlayer.state.status;\n  }\n\n  /**\n   * Disconnects from voice\n   * @returns {void}\n   */\n  disconnect() {\n    try {\n      if (this.audioPlayer) this.audioPlayer.stop(true);\n      if (this.voiceConnection.state.status !== VoiceConnectionStatus.Destroyed) this.voiceConnection.destroy();\n    } catch {} // eslint-disable-line no-empty\n  }\n\n  /**\n   * Destroys this dispatcher\n   */\n  public destroy() {\n    this.disconnect();\n    // @ts-ignore\n    this.audioPlayer.removeAllListeners();\n    // @ts-ignore\n    this.voiceConnection.removeAllListeners();\n    this.dsp.destroy();\n    this.audioResource = null;\n    this.emit('destroyed');\n  }\n\n  /**\n   * Stops the player\n   * @returns {void}\n   */\n  end() {\n    try {\n      this.audioPlayer.stop();\n      this.dsp.destroy();\n    } catch {\n\n      //\n    }}\n\n  /**\n   * Pauses the stream playback\n   * @param {boolean} [interpolateSilence=false] If true, the player will play 5 packets of silence after pausing to prevent audio glitches.\n   * @returns {boolean}\n   */\n  pause(interpolateSilence?: boolean) {\n    const success = this.audioPlayer.pause(interpolateSilence);\n    return success;\n  }\n\n  /**\n   * Resumes the stream playback\n   * @returns {boolean}\n   */\n  resume() {\n    const success = this.audioPlayer.unpause();\n    return success;\n  }\n\n  /**\n   * Play stream\n   * @param {AudioResource<Track>} [resource=this.audioResource] The audio resource to play\n   * @param {boolean} [opus=false] Whether or not to use opus\n   * @returns {Promise<StreamDispatcher>}\n   */\n  async playStream(resource: AudioResource<Track> = this.audioResource!) {\n    if (!resource) {\n      throw new NoAudioResourceError();\n    }\n    if (resource.ended) {\n      return void this.emit('finish', resource);\n    }\n    if (!this.audioResource) this.audioResource = resource;\n    if (this.voiceConnection.state.status !== VoiceConnectionStatus.Ready) {\n      try {\n        await entersState(this.voiceConnection, VoiceConnectionStatus.Ready, this.connectionTimeout);\n      } catch (err) {\n        return void this.emit('error', err as AudioPlayerError);\n      }\n    }\n\n    try {\n      this.audioPlayer.play(resource);\n    } catch (e) {\n      this.emit('error', e as AudioPlayerError);\n    }\n\n    return this;\n  }\n\n  /**\n   * Sets playback volume\n   * @param {number} value The volume amount\n   * @returns {boolean}\n   */\n  setVolume(value: number) {\n    if (!this.dsp.volume) return false;\n    return this.dsp.volume.setVolume(value);\n  }\n\n  /**\n   * The current volume\n   * @type {number}\n   */\n  get volume() {\n    if (!this.dsp.volume) return 100;\n    return this.dsp.volume.volume;\n  }\n\n  /**\n   * The playback time\n   * @type {number}\n   */\n  get streamTime() {\n    if (!this.audioResource) return 0;\n    return this.audioResource.playbackDuration;\n  }\n}\n\nexport { StreamDispatcher };", "import { Queue } from '@discord-player/utils';\nimport { NoResultError } from '../errors';\nimport { Track } from '../fabric/Track';\nimport { GuildQueue, TrackSkipReason } from './GuildQueue';\n\nexport class GuildQueueHistory<Meta = unknown> {\n  public tracks = new Queue<Track>('LIFO');\n  public constructor(public queue: GuildQueue<Meta>) {}\n\n  /**\n   * Current track in the queue\n   */\n  public get currentTrack() {\n    // eslint-disable-next-line @typescript-eslint/no-explicit-any\n    return this.queue.dispatcher?.audioResource?.metadata || (this.queue as any).__current as Track | null;\n  }\n\n  /**\n   * Next track in the queue\n   */\n  public get nextTrack() {\n    return this.queue.tracks.at(0) || null;\n  }\n\n  /**\n   * Previous track in the queue\n   */\n  public get previousTrack() {\n    return this.tracks.at(0) || null;\n  }\n\n  /**\n   * If history is disabled\n   */\n  public get disabled() {\n    return this.queue.options.disableHistory;\n  }\n\n  /**\n   * Gets the size of the queue\n   */\n  public get size() {\n    return this.tracks.size;\n  }\n\n  public getSize() {\n    return this.size;\n  }\n\n  /**\n   * If history is empty\n   */\n  public isEmpty() {\n    return this.tracks.size < 1;\n  }\n\n  /**\n   * Add track to track history\n   * @param track The track to add\n   */\n  public push(track: Track | Track[]) {\n    if (this.disabled) return false;\n    this.tracks.add(track);\n\n    this.resize();\n\n    return true;\n  }\n\n  /**\n   * Clear history\n   */\n  public clear() {\n    this.tracks.clear();\n  }\n\n  /**\n   * Play the next track in the queue\n   */\n  public async next() {\n    const track = this.nextTrack;\n    if (!track) {\n      throw new NoResultError('No next track in the queue');\n    }\n\n    this.queue.node.skip({\n      reason: TrackSkipReason.HistoryNext,\n      description: 'Skipped by GuildQueueHistory.next()'\n    });\n  }\n\n  /**\n   * Play the previous track in the queue\n   */\n  public async previous(preserveCurrent = true) {\n    const track = this.tracks.dispatch();\n    if (!track) {\n      throw new NoResultError('No previous track in the queue');\n    }\n\n    const current = this.currentTrack;\n\n    await this.queue.node.play(track, { queue: false });\n    if (current && preserveCurrent) this.queue.node.insert(current, 0);\n  }\n\n  /**\n   * Alias to [GuildQueueHistory].previous()\n   */\n  public back(preserveCurrent = true) {\n    return this.previous(preserveCurrent);\n  }\n\n  /**\n   * Resize history store\n   */\n  public resize() {\n    if (!Number.isFinite(this.queue.maxHistorySize)) return;\n    if (this.tracks.store.length < this.queue.maxHistorySize) return;\n    this.tracks.store.splice(this.queue.maxHistorySize);\n  }\n}", "import { AudioResource, StreamType } from 'discord-voip';\nimport { Readable } from 'stream';\nimport { QueryResolver, SearchQueryType } from '../utils/QueryResolver';\nimport { Util, VALIDATE_QUEUE_CAP } from '../utils/Util';\nimport { Track, TrackResolvable } from '../fabric/Track';\nimport { GuildQueue, GuildQueueEvent, TrackSkipReason } from './GuildQueue';\nimport { setTimeout as waitFor } from 'timers/promises';\nimport { AsyncQueue } from '../utils/AsyncQueue';\nimport { InvalidArgTypeError, NoResultError, NoVoiceConnectionError, OutOfRangeError } from '../errors';\nimport { TypeUtil } from '../utils/TypeUtil';\nimport { CreateStreamOps } from '../stream/StreamDispatcher';\nimport { ExtractorStreamable } from '../extractors/BaseExtractor';\nimport { OggDemuxer, OpusDecoder, WebmDemuxer } from '@discord-player/opus';\n\nexport const FFMPEG_SRATE_REGEX = /asetrate=\\d+\\*(\\d(\\.\\d)?)/;\n\nexport interface PlayerProgressbarOptions {\n  /**\n   * If it should render time codes\n   */\n  timecodes?: boolean;\n  /**\n   * If it should create progress bar for the whole queue\n   */\n  length?: number;\n  /**\n   * The bar length\n   */\n  leftChar?: string;\n  /**\n   * The elapsed time track\n   */\n  rightChar?: string;\n  /**\n   * The remaining time track\n   */\n  separator?: string;\n  /**\n   * The separation between timestamp and line\n   */\n  indicator?: string;\n  /**\n   * The indicator\n   */\n  queue?: boolean;\n}\n\nexport interface ResourcePlayOptions {\n  queue?: boolean;\n  seek?: number;\n  transitionMode?: boolean;\n}\n\nexport interface SkipOptions {\n  reason: TrackSkipReason;\n  description: string;\n}\n\nexport interface PlayerTimestamp {\n  current: {\n    label: string;\n    value: number;\n  };\n  total: {\n    label: string;\n    value: number;\n  };\n  progress: number;\n}\n\nexport interface StreamConfig {\n  dispatcherConfig: CreateStreamOps;\n  playerConfig: ResourcePlayOptions;\n}\n\nexport class GuildQueuePlayerNode<Meta = unknown> {\n  #progress = 0;\n  #hasFFmpegOptimization = false;\n  public tasksQueue = new AsyncQueue();\n  public constructor(public queue: GuildQueue<Meta>) {\n    this.#hasFFmpegOptimization = /libopus: (yes|true)/.test(this.queue.player.scanDeps());\n  }\n\n  /**\n   * If the player is currently in idle mode\n   */\n  public isIdle() {\n    return !!this.queue.dispatcher?.isIdle();\n  }\n\n  /**\n   * If the player is currently buffering the track\n   */\n  public isBuffering() {\n    return !!this.queue.dispatcher?.isBuffering();\n  }\n\n  /**\n   * If the player is currently playing a track\n   */\n  public isPlaying() {\n    return !!this.queue.dispatcher?.isPlaying();\n  }\n\n  /**\n   * If the player is currently paused\n   */\n  public isPaused() {\n    return !!this.queue.dispatcher?.isPaused();\n  }\n\n  /**\n   * Reset progress history\n   */\n  public resetProgress() {\n    this.#progress = 0;\n  }\n\n  /**\n   * Set player progress\n   */\n  public setProgress(progress: number) {\n    this.#progress = progress;\n  }\n\n  /**\n   * The stream time for current session\n   */\n  public get streamTime() {\n    return this.queue.dispatcher?.streamTime ?? 0;\n  }\n\n  /**\n   * Current playback duration with history included\n   */\n  public get playbackTime() {\n    const dur = this.#progress + this.streamTime;\n\n    return dur;\n  }\n\n  /**\n   * Get duration multiplier\n   */\n  public getDurationMultiplier() {\n    const srateFilters = this.queue.filters.ffmpeg.toArray().filter((ff) => FFMPEG_SRATE_REGEX.test(ff));\n    const multipliers = srateFilters.\n    map((m) => {\n      return parseFloat(FFMPEG_SRATE_REGEX.exec(m)?.[1] as string);\n    }).\n    filter((f) => !isNaN(f));\n\n    return !multipliers.length ? 1 : multipliers.reduce((accumulator, current) => current + accumulator);\n  }\n\n  /**\n   * Estimated progress of the player\n   */\n  public get estimatedPlaybackTime() {\n    const dur = this.playbackTime;\n    return Math.round(this.getDurationMultiplier() * dur);\n  }\n\n  /**\n   * Estimated total duration of the player\n   */\n  public get estimatedDuration() {\n    const dur = this.totalDuration;\n\n    return Math.round(dur / this.getDurationMultiplier());\n  }\n\n  /**\n   * Total duration of the current audio track\n   */\n  public get totalDuration() {\n    const prefersBridgedMetadata = this.queue.options.preferBridgedMetadata;\n    const track = this.queue.currentTrack;\n\n    if (prefersBridgedMetadata) {\n      const trackHasLegacyMetadata =\n      track?.metadata != null &&\n      typeof track.metadata === 'object' &&\n      'bridge' in track.metadata &&\n      track.metadata.bridge != null;\n      const trackHasMetadata = track?.bridgedTrack != null;\n\n      if (trackHasLegacyMetadata || trackHasMetadata) {\n        const duration =\n        track.bridgedTrack?.durationMS ??\n        (\n        track as Track<{\n          bridge: {\n            duration: number;\n          };\n        }>).\n        metadata?.bridge.duration;\n\n        if (TypeUtil.isNumber(duration)) return duration;\n      }\n    }\n\n    return track?.durationMS ?? 0;\n  }\n\n  /**\n   * Get stream progress\n   * @param ignoreFilters Ignore filters\n   */\n  public getTimestamp(ignoreFilters = false): PlayerTimestamp | null {\n    if (!this.queue.currentTrack) return null;\n\n    const current = ignoreFilters ? this.playbackTime : this.estimatedPlaybackTime;\n    const total = ignoreFilters ? this.totalDuration : this.estimatedDuration;\n\n    return {\n      current: {\n        label: Util.buildTimeCode(Util.parseMS(current)),\n        value: current\n      },\n      total: {\n        label: Util.buildTimeCode(Util.parseMS(total)),\n        value: total\n      },\n      progress: Math.round(current / total * 100)\n    };\n  }\n\n  /**\n   * Create progress bar for current progress\n   * @param options Progress bar options\n   */\n  public createProgressBar(options?: PlayerProgressbarOptions) {\n    const timestamp = this.getTimestamp();\n    if (!timestamp) return null;\n    const {\n      indicator = '\\u{1F518}',\n      leftChar = '\\u25AC',\n      rightChar = '\\u25AC',\n      length = 15,\n      timecodes = true,\n      separator = '\\u2503'\n    } = options || {};\n    if (isNaN(length) || length < 0 || !Number.isFinite(length)) {\n      throw new OutOfRangeError('[PlayerProgressBarOptions.length]', String(length), '0', 'Finite Number');\n    }\n    const index = Math.round(timestamp.current.value / timestamp.total.value * length);\n    if (index >= 1 && index <= length) {\n      const bar = leftChar.repeat(index - 1).split('');\n      bar.push(indicator);\n      bar.push(rightChar.repeat(length - index));\n      if (timecodes) {\n        return `${timestamp.current.label} ${separator} ${bar.join('')} ${separator} ${timestamp.total.label}`;\n      } else {\n        return `${bar.join('')}`;\n      }\n    } else {\n      if (timecodes) {\n        return `${timestamp.current.label} ${separator} ${indicator}${rightChar.repeat(length - 1)} ${separator} ${\n        timestamp.total.label}`;\n\n      } else {\n        return `${indicator}${rightChar.repeat(length - 1)}`;\n      }\n    }\n  }\n\n  /**\n   * Seek the player\n   * @param duration The duration to seek to\n   */\n  public async seek(duration: number) {\n    if (!this.queue.currentTrack) return false;\n    if (duration === this.estimatedPlaybackTime) return true;\n    if (duration > this.totalDuration) {\n      return this.skip({\n        reason: TrackSkipReason.SEEK_OVER_THRESHOLD,\n        description: new OutOfRangeError('[duration]', String(duration), '0', String(this.totalDuration)).message\n      });\n    }\n    if (duration < 0) duration = 0;\n    return await this.queue.filters.triggerReplay(duration);\n  }\n\n  /**\n   * Current volume\n   */\n  public get volume() {\n    return this.queue.dispatcher?.volume ?? 100;\n  }\n\n  /**\n   * Set volume\n   * @param vol Volume amount to set\n   */\n  public setVolume(vol: number) {\n    if (!this.queue.dispatcher) return false;\n    const res = this.queue.dispatcher.setVolume(vol);\n    if (res) this.queue.filters._lastFiltersCache.volume = vol;\n    return res;\n  }\n\n  /**\n   * Set bit rate\n   * @param rate The bit rate to set\n   */\n  public setBitrate(rate: number | 'auto') {\n    this.queue.dispatcher?.audioResource?.encoder?.setBitrate(\n      rate === 'auto' ? this.queue.channel?.bitrate ?? 64000 : rate\n    );\n  }\n\n  /**\n   * Set paused state\n   * @param state The state\n   */\n  public setPaused(state: boolean) {\n    if (state) return this.queue.dispatcher?.pause(true) || false;\n    return this.queue.dispatcher?.resume() || false;\n  }\n\n  /**\n   * Pause the playback\n   */\n  public pause() {\n    return this.setPaused(true);\n  }\n\n  /**\n   * Resume the playback\n   */\n  public resume() {\n    return this.setPaused(false);\n  }\n\n  /**\n   * Skip current track\n   */\n  public skip(options?: SkipOptions) {\n    if (!this.queue.dispatcher) return false;\n    const track = this.queue.currentTrack;\n    if (!track) return false;\n    this.queue.setTransitioning(false);\n    this.queue.dispatcher.end();\n    const { reason, description } = options || {\n      reason: TrackSkipReason.Manual,\n      description: 'The track was skipped manually'\n    };\n    this.queue.emit(GuildQueueEvent.PlayerSkip, this.queue, track, reason, description);\n    return true;\n  }\n\n  /**\n   * Remove the given track from queue\n   * @param track The track to remove\n   * @param emitEvent Whether or not to emit the event @defaultValue true\n   */\n  public remove(track: TrackResolvable, emitEvent = true) {\n    const foundTrack = this.queue.tracks.find((t, idx) => {\n      if (track instanceof Track || typeof track === 'string') {\n        return (typeof track === 'string' ? track : track.id) === t.id;\n      }\n      if (typeof track === 'string') return track === t.id;\n      return idx === track;\n    });\n    if (!foundTrack) return null;\n\n    this.queue.tracks.removeOne((t) => t.id === foundTrack.id);\n\n    if (emitEvent) this.queue.emit(GuildQueueEvent.AudioTrackRemove, this.queue, foundTrack);\n\n    return foundTrack;\n  }\n\n  /**\n   * Jump to specific track on the queue\n   * @param track The track to jump to without removing other tracks\n   */\n  public jump(track: TrackResolvable) {\n    const removed = this.remove(track, false);\n    if (!removed) return false;\n    this.queue.tracks.store.unshift(removed);\n    return this.skip({\n      reason: TrackSkipReason.Jump,\n      description: 'The track was jumped to manually'\n    });\n  }\n\n  /**\n   * Get track position\n   * @param track The track\n   */\n  public getTrackPosition(track: TrackResolvable): number {\n    return this.queue.tracks.toArray().findIndex((t, idx) => {\n      if (track instanceof Track || typeof track === 'string') {\n        return (typeof track === 'string' ? track : track.id) === t.id;\n      }\n      if (typeof track === 'string') return track === t.id;\n      return idx === track;\n    });\n  }\n\n  /**\n   * Skip to the given track, removing others on the way\n   * @param track The track to skip to\n   */\n  public skipTo(track: TrackResolvable) {\n    const idx = this.getTrackPosition(track);\n    if (idx < 0) return false;\n    const removed = this.remove(idx);\n    if (!removed) return false;\n    const toRemove = this.queue.tracks.store.filter((_, i) => i <= idx);\n    this.queue.tracks.store.splice(0, idx, removed);\n    this.queue.emit(GuildQueueEvent.AudioTracksRemove, this.queue, toRemove);\n    return this.skip({\n      reason: TrackSkipReason.SkipTo,\n      description: 'The player was skipped to another track manually'\n    });\n  }\n\n  /**\n   * Insert a track on the given position in queue\n   * @param track The track to insert\n   * @param index The position to insert to, defaults to 0.\n   */\n  public insert(track: Track, index = 0) {\n    if (!(track instanceof Track)) throw new InvalidArgTypeError('track value', 'instance of Track', String(track));\n    VALIDATE_QUEUE_CAP(this.queue, track);\n    this.queue.tracks.store.splice(index, 0, track);\n    if (!this.queue.options.noEmitInsert) this.queue.emit(GuildQueueEvent.AudioTrackAdd, this.queue, track);\n  }\n\n  /**\n   * Moves a track in the queue\n   * @param from The track to move\n   * @param to The position to move to\n   */\n  public move(from: TrackResolvable, to: number) {\n    const removed = this.remove(from);\n    if (!removed) {\n      throw new NoResultError('invalid track to move');\n    }\n    this.insert(removed, to);\n  }\n\n  /**\n   * Copy a track in the queue\n   * @param from The track to clone\n   * @param to The position to clone at\n   */\n  public copy(from: TrackResolvable, to: number) {\n    const src = this.queue.tracks.at(this.getTrackPosition(from));\n    if (!src) {\n      throw new NoResultError('invalid track to copy');\n    }\n    this.insert(src, to);\n  }\n\n  /**\n   * Swap two tracks in the queue\n   * @param first The first track to swap\n   * @param second The second track to swap\n   */\n  public swap(first: TrackResolvable, second: TrackResolvable) {\n    const src = this.getTrackPosition(first);\n    if (src < 0) throw new NoResultError('invalid src track to swap');\n\n    const dest = this.getTrackPosition(second);\n    if (dest < 0) throw new NoResultError('invalid dest track to swap');\n\n    const srcT = this.queue.tracks.store[src];\n    const destT = this.queue.tracks.store[dest];\n\n    this.queue.tracks.store[src] = destT;\n    this.queue.tracks.store[dest] = srcT;\n  }\n\n  /**\n   * Stop the playback\n   * @param force Whether or not to forcefully stop the playback\n   */\n  public stop(force = false) {\n    this.queue.tracks.clear();\n    this.queue.history.clear();\n    if (!this.queue.dispatcher) return false;\n    this.queue.dispatcher.end();\n    if (force) {\n      this.queue.dispatcher.destroy();\n      return true;\n    }\n    if (this.queue.options.leaveOnStop) {\n      const tm: NodeJS.Timeout = setTimeout(() => {\n        if (this.isPlaying() || this.queue.tracks.size) return clearTimeout(tm);\n        this.queue.dispatcher?.destroy();\n      }, this.queue.options.leaveOnStopCooldown).unref();\n    }\n    return true;\n  }\n\n  /**\n   * Play the given track\n   * @param res The track to play\n   * @param options Options for playing the track\n   */\n  public async play(res?: Track | null, options?: ResourcePlayOptions) {\n    if (!this.queue.dispatcher?.voiceConnection) {\n      throw new NoVoiceConnectionError();\n    }\n\n    if (this.queue.hasDebugger)\n    this.queue.debug(`Received play request from guild ${this.queue.guild.name} (ID: ${this.queue.guild.id})`);\n\n    options = Object.assign(\n      {},\n      {\n        queue: this.queue.currentTrack != null,\n        transitionMode: false,\n        seek: 0\n      } as ResourcePlayOptions,\n      options\n    )!;\n\n    if (res && options.queue) {\n      if (this.queue.hasDebugger)\n      this.queue.debug('Requested option requires to queue the track, adding the given track to queue instead...');\n      return this.queue.addTrack(res);\n    }\n\n    const track = res || this.queue.tracks.dispatch();\n    if (!track) {\n      const error = new NoResultError('Play request received but track was not provided');\n      this.queue.emit(GuildQueueEvent.Error, this.queue, error);\n      return;\n    }\n\n    if (this.queue.hasDebugger) this.queue.debug('Requested option requires to play the track, initializing...');\n\n    try {\n      const assignedResource = track.resource;\n\n      if (assignedResource) {\n        if (this.queue.hasDebugger)\n        this.queue.debug('Track has an audio resource assigned, player will now play the resource directly...');\n\n        this.queue.setTransitioning(!!options.transitionMode);\n\n        return this.#performPlay(assignedResource);\n      }\n\n      if (this.queue.hasDebugger) this.queue.debug(`Initiating stream extraction process...`);\n      const src = track.raw?.source || track.source;\n      const qt: SearchQueryType =\n      track.queryType || (src === 'spotify' ? 'spotifySong' : src === 'apple_music' ? 'appleMusicSong' : src);\n      if (this.queue.hasDebugger) this.queue.debug(`Executing onBeforeCreateStream hook (QueryType: ${qt})...`);\n\n      const streamSrc = {\n        error: null as Error | null,\n        stream: null as ExtractorStreamable | null\n      };\n\n      await this.queue.onBeforeCreateStream?.(track, qt || 'arbitrary', this.queue).then(\n        (s) => {\n          if (s) {\n            streamSrc.stream = s;\n          }\n        },\n        (e: Error) => streamSrc.error = e\n      );\n\n      // throw if 'onBeforeCreateStream' panics\n      if (!streamSrc.stream && streamSrc.error) return this.#throw(track, streamSrc.error);\n\n      // default behavior when 'onBeforeCreateStream' did not panic\n      if (!streamSrc.stream) {\n        if (this.queue.hasDebugger) this.queue.debug('Failed to get stream from onBeforeCreateStream!');\n        await this.queue.player.extractors.context.provide(\n          {\n            id: crypto.randomUUID(),\n            attemptedExtractors: new Set<string>(),\n            bridgeAttemptedExtractors: new Set<string>()\n          },\n          () =>\n          this.#createGenericStream(track).then(\n            (r) => {\n              if (r?.result) {\n                streamSrc.stream = <Readable> r.result;\n                return;\n              }\n\n              if (r?.error) {\n                streamSrc.error = r.error;\n                return;\n              }\n\n              streamSrc.stream = streamSrc.error = null;\n            },\n            (e: Error) => streamSrc.error = e\n          )\n        );\n      }\n\n      if (!streamSrc.stream) return this.#throw(track, streamSrc.error);\n\n      if (typeof options.seek === 'number' && options.seek >= 0) {\n        this.#progress = options.seek;\n      } else {\n        this.#progress = 0;\n      }\n\n      const trackStreamConfig: StreamConfig = {\n        dispatcherConfig: {\n          disableBiquad: this.queue.options.disableBiquad,\n          disableEqualizer: this.queue.options.disableEqualizer,\n          disableVolume: this.queue.options.disableVolume,\n          disableFilters: this.queue.options.disableFilterer,\n          disableResampler: this.queue.options.disableResampler,\n          sampleRate:\n          typeof this.queue.options.resampler === 'number' && this.queue.options.resampler > 0 ?\n          this.queue.options.resampler :\n          undefined,\n          biquadFilter: this.queue.filters._lastFiltersCache.biquad || undefined,\n          eq: this.queue.filters._lastFiltersCache.equalizer,\n          defaultFilters: this.queue.filters._lastFiltersCache.filters,\n          volume: this.queue.filters._lastFiltersCache.volume,\n          data: track,\n          type: StreamType.Raw,\n          skipFFmpeg: this.queue.player.options.skipFFmpeg\n        },\n        playerConfig: options\n      };\n\n      let resolver: () => void = Util.noop;\n      const donePromise = new Promise<void>((resolve) => resolver = resolve);\n\n      const success = this.queue.emit(GuildQueueEvent.WillPlayTrack, this.queue, track, trackStreamConfig, resolver!);\n\n      // prevent dangling promise\n      if (!success) resolver();\n\n      if (this.queue.hasDebugger) this.queue.debug('Waiting for willPlayTrack event to resolve...');\n\n      await donePromise;\n\n      // prettier-ignore\n      const daspDisabled = [\n      trackStreamConfig.dispatcherConfig.disableBiquad,\n      trackStreamConfig.dispatcherConfig.disableEqualizer,\n      trackStreamConfig.dispatcherConfig.disableFilters,\n      trackStreamConfig.dispatcherConfig.disableResampler,\n      trackStreamConfig.dispatcherConfig.disableVolume].\n      every((e) => !!e === true);\n\n      const needsFilters = !!trackStreamConfig.playerConfig.seek || !!this.queue.filters.ffmpeg.args.length;\n      const shouldSkipFFmpeg = !!trackStreamConfig.dispatcherConfig.skipFFmpeg && !needsFilters;\n\n      let finalStream: Readable;\n\n      const demuxable = (fmt: string) =>\n      [StreamType.Opus, StreamType.WebmOpus, StreamType.OggOpus].includes(fmt as StreamType);\n\n      // skip ffmpeg when possible\n      if (\n      shouldSkipFFmpeg &&\n      !(streamSrc.stream instanceof Readable) &&\n      typeof streamSrc.stream !== 'string' &&\n      demuxable(streamSrc.stream.$fmt))\n      {\n        const { $fmt, stream } = streamSrc.stream;\n        const shouldPCM = !daspDisabled;\n\n        if (this.queue.hasDebugger)\n        this.queue.debug(\n          `skipFFmpeg is set to true and stream is demuxable, creating stream with type ${\n          shouldPCM ? 'pcm' : 'opus'}`\n\n        );\n\n        // prettier-ignore\n        const opusStream = $fmt === StreamType.Opus ?\n        stream :\n        $fmt === StreamType.OggOpus ?\n        // eslint-disable-next-line @typescript-eslint/no-explicit-any\n        stream.pipe(new OggDemuxer() as any) :\n        // eslint-disable-next-line @typescript-eslint/no-explicit-any\n        stream.pipe(new WebmDemuxer() as any);\n\n        if (shouldPCM) {\n          // if we have any filters enabled, we need to decode the opus stream to pcm\n          finalStream = opusStream.pipe(\n            new OpusDecoder({\n              channels: 2,\n              frameSize: 960,\n              rate: 48000\n            })\n          );\n          trackStreamConfig.dispatcherConfig.type = StreamType.Raw;\n        } else {\n          finalStream = opusStream;\n          trackStreamConfig.dispatcherConfig.type = StreamType.Opus;\n        }\n      } else {\n        // const opus = daspDisabled && this.#hasFFmpegOptimization;\n        // if (opus && this.queue.hasDebugger) this.queue.debug('Disabling PCM output since all filters are disabled and opus encoding is supported...');\n\n        finalStream = this.#createFFmpegStream(\n          streamSrc.stream instanceof Readable || typeof streamSrc.stream === 'string' ?\n          streamSrc.stream :\n          streamSrc.stream.stream,\n          track,\n          options.seek ?? 0\n          // opus\n        );\n        trackStreamConfig.dispatcherConfig.type = StreamType.Raw;\n        // FIXME: OggOpus results in static noise\n        // trackStreamConfig.dispatcherConfig.type = opus ? StreamType.OggOpus : StreamType.Raw;\n      }\n\n      if (options.transitionMode) {\n        if (this.queue.hasDebugger)\n        this.queue.debug(\n          `Transition mode detected, player will wait for buffering timeout to expire (Timeout: ${this.queue.options.bufferingTimeout}ms)`\n        );\n        await waitFor(this.queue.options.bufferingTimeout);\n        if (this.queue.hasDebugger) this.queue.debug('Buffering timeout has expired!');\n      }\n\n      if (this.queue.hasDebugger)\n      this.queue.debug(`Preparing final stream config: ${JSON.stringify(trackStreamConfig, null, 2)}`);\n\n      const dispatcher = this.queue.dispatcher;\n\n      if (!dispatcher) {\n        if (this.queue.hasDebugger) {\n          this.queue.debug(\n            'Dispatcher is not available, this is most likely due to the queue being deleted in the middle of operation. Cancelling the stream...'\n          );\n        }\n\n        finalStream.destroy();\n      } else {\n        const resource = await dispatcher.createStream(finalStream, trackStreamConfig.dispatcherConfig);\n\n        this.queue.setTransitioning(!!options.transitionMode);\n\n        await this.#performPlay(resource);\n      }\n    } catch (e) {\n      if (this.queue.hasDebugger) this.queue.debug(`Failed to initialize audio player: ${e}`);\n      throw e;\n    }\n  }\n\n  #throw(track: Track, error?: Error | null): void {\n    // prettier-ignore\n    const streamDefinitelyFailedMyDearT_TPleaseTrustMeItsNotMyFault =\n    new NoResultError(`Could not extract stream for this track${error ? `\\n\\n${error.stack || error}` : ''}`);\n\n\n    this.queue.emit(\n      GuildQueueEvent.PlayerSkip,\n      this.queue,\n      track,\n      TrackSkipReason.NoStream,\n      streamDefinitelyFailedMyDearT_TPleaseTrustMeItsNotMyFault.message\n    );\n    this.queue.emit(\n      GuildQueueEvent.PlayerError,\n      this.queue,\n      streamDefinitelyFailedMyDearT_TPleaseTrustMeItsNotMyFault,\n      track\n    );\n    const nextTrack = this.queue.tracks.dispatch();\n    if (nextTrack) return void this.play(nextTrack, { queue: false });\n    // @ts-expect-error should be resolved\n    this.queue.dispatcher?.emit('finish', null);\n  }\n\n  async #performPlay(resource: AudioResource<Track>) {\n    if (!this.queue.dispatcher) {\n      if (this.queue.hasDebugger) {\n        this.queue.debug(\n          'Dispatcher is not available, this is most likely due to the queue being deleted in the middle of operation. Cancelling the stream...'\n        );\n      }\n    } else {\n      if (this.queue.hasDebugger) this.queue.debug('Initializing audio player...');\n      await this.queue.dispatcher.playStream(resource);\n      if (this.queue.hasDebugger) this.queue.debug('Dispatching audio...');\n    }\n  }\n\n  async #createGenericStream(track: Track) {\n    if (this.queue.hasDebugger)\n    this.queue.debug(\n      `Attempting to extract stream for Track { title: ${track.title}, url: ${track.url} } using registered extractors`\n    );\n\n    const attemptedExtractors = this.queue.player.extractors.getContext()?.attemptedExtractors || new Set<string>();\n\n    const streamInfo = await this.queue.player.extractors.run(async (extractor) => {\n      if (this.queue.player.options.blockStreamFrom?.some((ext) => ext === extractor.identifier)) return false;\n      if (attemptedExtractors.has(extractor.identifier)) return false;\n      attemptedExtractors.add(extractor.identifier);\n      const canStream = await extractor.validate(track.url, track.queryType || QueryResolver.resolve(track.url).type);\n      if (!canStream) return false;\n      return await extractor.stream(track);\n    }, false);\n\n    if (!streamInfo || !streamInfo.result) {\n      if (this.queue.hasDebugger) {\n        this.queue.debug(\n          `Failed to extract stream for Track { title: ${track.title}, url: ${track.url} } using registered extractors`\n        );\n      }\n\n      if (!this.queue.options.disableFallbackStream) {\n        if (this.queue.hasDebugger)\n        this.queue.debug(`Generic stream extraction failed and fallback stream extraction is enabled`);\n        return this.#createFallbackStream(track);\n      }\n\n      return streamInfo || null;\n    }\n\n    if (this.queue.hasDebugger)\n    this.queue.debug(\n      `Stream extraction was successful for Track { title: ${track.title}, url: ${track.url} } (Extractor: ${\n      streamInfo.extractor?.identifier || 'N/A'})`\n\n    );\n\n    return streamInfo;\n  }\n\n  async #createFallbackStream(track: Track) {\n    if (this.queue.hasDebugger)\n    this.queue.debug(\n      `Attempting to extract stream for Track { title: ${track.title}, url: ${track.url} } using fallback streaming method...`\n    );\n\n    const fallbackStream = await this.queue.player.extractors.run(async (extractor) => {\n      if (extractor.identifier === track.extractor?.identifier) return false;\n      if (this.queue.player.options.blockStreamFrom?.some((ext) => ext === extractor.identifier)) return false;\n\n      const query = `${track.title} ${track.author}`;\n      const fallbackTracks = await extractor.handle(query, {\n        requestedBy: track.requestedBy\n      });\n\n      const fallbackTrack = fallbackTracks.tracks[0];\n\n      if (!fallbackTrack) return false;\n\n      const stream = await extractor.stream(fallbackTrack);\n\n      if (!stream) return false;\n\n      track.bridgedTrack = fallbackTrack;\n\n      return stream;\n    }, true);\n\n    if (!fallbackStream || !fallbackStream.result) {\n      if (this.queue.hasDebugger)\n      this.queue.debug(\n        `Failed to extract stream for Track { title: ${track.title}, url: ${track.url} } using fallback streaming method`\n      );\n      return fallbackStream || null;\n    }\n\n    track.bridgedExtractor = fallbackStream.extractor;\n\n    return fallbackStream;\n  }\n\n  #createFFmpegStream(stream: Readable | string, track: Track, seek = 0, opus?: boolean) {\n    const ffmpegStream = this.queue.filters.ffmpeg.\n    createStream(stream, {\n      encoderArgs: this.queue.filters.ffmpeg.args,\n      seek: seek / 1000,\n      fmt: opus ? 'opus' : 's16le'\n    }).\n    on('error', (err) => {\n      const m = `${err}`.toLowerCase();\n\n      if (this.queue.hasDebugger)\n      this.queue.debug(`Stream closed due to an error from FFmpeg stream: ${err.stack || err.message || err}`);\n\n      if (m.includes('premature close') || m.includes('epipe')) return;\n\n      this.queue.emit(GuildQueueEvent.PlayerError, this.queue, err, track);\n    });\n\n    return ffmpegStream;\n  }\n}", "import { SnowflakeUtil } from 'discord.js';\n\nexport interface AsyncQueueAcquisitionOptions {\n  /**\n   * AbortSignal to cancel this entry\n   */\n  signal?: AbortSignal;\n}\n\nexport type AsyncQueueExceptionHandler = (exception: Error) => void;\n\nexport class AsyncQueue {\n  /**\n   * The queued entries\n   */\n  public entries: Array<AsyncQueueEntry> = [];\n\n  public exceptionHandler?: AsyncQueueExceptionHandler;\n\n  /**\n   * Clear entries queue\n   * @param consume Whether or not to consume all entries before clearing\n   */\n  public clear(consume = false) {\n    if (consume) {\n      this.entries.forEach((entry) => entry.consume());\n    }\n\n    this.entries = [];\n  }\n\n  /**\n   * The total number of entries in this queue. Returns `0` if no entries are available.\n   */\n  public get size() {\n    return this.entries.length;\n  }\n\n  /**\n   * Acquire an entry.\n   *\n   * @example // lock the queue\n   * const entry = asyncQueue.acquire();\n   * // wait until previous task is completed\n   * await entry.getTask();\n   * // do something expensive\n   * await performSomethingExpensive();\n   * // make sure to release the lock once done\n   * asyncQueue.release();\n   *\n   */\n  public acquire(options?: AsyncQueueAcquisitionOptions) {\n    const entry = new AsyncQueueEntry(this, options);\n\n    if (this.exceptionHandler) entry.getTask().catch(this.exceptionHandler);\n\n    if (this.entries.length === 0) {\n      this.entries.push(entry);\n      entry.consume();\n      return entry;\n    }\n\n    this.entries.push(entry);\n    return entry;\n  }\n\n  /**\n   * Release the current acquisition and move to next entry.\n   */\n  public release(): void {\n    if (!this.entries.length) return;\n\n    this.entries.shift();\n    this.entries[0]?.consume();\n  }\n\n  /**\n   * Cancel all entries\n   */\n  public cancelAll() {\n    this.entries.forEach((entry) => entry.cancel());\n  }\n\n  /**\n   * Remove the given entry from the queue\n   * @param entry The entry to remove\n   */\n  public removeEntry(entry: AsyncQueueEntry) {\n    const entryIdx = this.entries.indexOf(entry);\n\n    if (entryIdx !== -1) {\n      this.entries.splice(entryIdx, 1);\n      return true;\n    }\n\n    return false;\n  }\n}\n\nexport class AsyncQueueEntry {\n  public readonly id = SnowflakeUtil.generate().toString();\n  private readonly promise: Promise<void>;\n  public signal: AbortSignal | null = null;\n  public onAbort: (() => void) | null = null;\n  private resolve!: () => void;\n  private reject!: (err: Error) => void;\n\n  public constructor(public queue: AsyncQueue, public options?: AsyncQueueAcquisitionOptions) {\n    this.promise = new Promise((resolve, reject) => {\n      this.resolve = resolve;\n      this.reject = reject;\n    });\n\n    if (this.options?.signal) {\n      this.setAbortSignal(this.options.signal);\n    }\n  }\n\n  public setAbortSignal(signal: AbortSignal) {\n    if (signal.aborted) return;\n    this.signal = signal;\n    this.onAbort = () => {\n      this.queue.removeEntry(this);\n      this.cancel();\n    };\n\n    this.signal.addEventListener('abort', this.onAbort);\n  }\n\n  public consume() {\n    this.cleanup();\n    this.resolve();\n  }\n\n  public release() {\n    this.consume();\n    this.queue.release();\n  }\n\n  public cancel() {\n    this.cleanup();\n    this.reject(new Error('Cancelled'));\n  }\n\n  public cleanup() {\n    if (this.onAbort) this.signal?.removeEventListener('abort', this.onAbort);\n    this.signal = null;\n    this.onAbort = null;\n  }\n\n  public getTask() {\n    return this.promise;\n  }\n}", "import { Readable } from 'stream';\nimport { AudioFilters, FiltersName, QueueFilters } from '../utils/AudioFilters';\nimport { GuildQueue, GuildQueueEvent } from './GuildQueue';\nimport { BiquadFilters, Equalizer, EqualizerBand, PCMFilters } from '@discord-player/equalizer';\nimport { FFmpegStreamOptions, createFFmpegStream } from '../utils/FFmpegStream';\nimport { InvalidArgTypeError } from '../errors';\n\ntype Filters = keyof typeof AudioFilters.filters;\n\nconst makeBands = (arr: number[]) => {\n  return Array.from(\n    {\n      length: Equalizer.BAND_COUNT\n    },\n    (_, i) => ({\n      band: i,\n      gain: arr[i] ? arr[i] / 30 : 0\n    })\n  ) as EqualizerBand[];\n};\n\ntype EQPreset = {\n  Flat: EqualizerBand[];\n  Classical: EqualizerBand[];\n  Club: EqualizerBand[];\n  Dance: EqualizerBand[];\n  FullBass: EqualizerBand[];\n  FullBassTreble: EqualizerBand[];\n  FullTreble: EqualizerBand[];\n  Headphones: EqualizerBand[];\n  LargeHall: EqualizerBand[];\n  Live: EqualizerBand[];\n  Party: EqualizerBand[];\n  Pop: EqualizerBand[];\n  Reggae: EqualizerBand[];\n  Rock: EqualizerBand[];\n  Ska: EqualizerBand[];\n  Soft: EqualizerBand[];\n  SoftRock: EqualizerBand[];\n  Techno: EqualizerBand[];\n};\n\nexport const EqualizerConfigurationPreset: Readonly<EQPreset> = Object.freeze({\n  Flat: makeBands([]),\n  Classical: makeBands([\n  -1.11022e-15, -1.11022e-15, -1.11022e-15, -1.11022e-15, -1.11022e-15, -1.11022e-15, -7.2, -7.2, -7.2, -9.6]\n  ),\n  Club: makeBands([-1.11022e-15, -1.11022e-15, 8.0, 5.6, 5.6, 5.6, 3.2, -1.11022e-15, -1.11022e-15, -1.11022e-15]),\n  Dance: makeBands([9.6, 7.2, 2.4, -1.11022e-15, -1.11022e-15, -5.6, -7.2, -7.2, -1.11022e-15, -1.11022e-15]),\n  FullBass: makeBands([-8.0, 9.6, 9.6, 5.6, 1.6, -4.0, -8.0, -10.4, -11.2, -11.2]),\n  FullBassTreble: makeBands([7.2, 5.6, -1.11022e-15, -7.2, -4.8, 1.6, 8.0, 11.2, 12.0, 12.0]),\n  FullTreble: makeBands([-9.6, -9.6, -9.6, -4.0, 2.4, 11.2, 16.0, 16.0, 16.0, 16.8]),\n  Headphones: makeBands([4.8, 11.2, 5.6, -3.2, -2.4, 1.6, 4.8, 9.6, 12.8, 14.4]),\n  LargeHall: makeBands([10.4, 10.4, 5.6, 5.6, -1.11022e-15, -4.8, -4.8, -4.8, -1.11022e-15, -1.11022e-15]),\n  Live: makeBands([-4.8, -1.11022e-15, 4.0, 5.6, 5.6, 5.6, 4.0, 2.4, 2.4, 2.4]),\n  Party: makeBands([\n  7.2, 7.2, -1.11022e-15, -1.11022e-15, -1.11022e-15, -1.11022e-15, -1.11022e-15, -1.11022e-15, 7.2, 7.2]\n  ),\n  Pop: makeBands([-1.6, 4.8, 7.2, 8.0, 5.6, -1.11022e-15, -2.4, -2.4, -1.6, -1.6]),\n  Reggae: makeBands([\n  -1.11022e-15, -1.11022e-15, -1.11022e-15, -5.6, -1.11022e-15, 6.4, 6.4, -1.11022e-15, -1.11022e-15, -1.11022e-15]\n  ),\n  Rock: makeBands([8.0, 4.8, -5.6, -8.0, -3.2, 4.0, 8.8, 11.2, 11.2, 11.2]),\n  Ska: makeBands([-2.4, -4.8, -4.0, -1.11022e-15, 4.0, 5.6, 8.8, 9.6, 11.2, 9.6]),\n  Soft: makeBands([4.8, 1.6, -1.11022e-15, -2.4, -1.11022e-15, 4.0, 8.0, 9.6, 11.2, 12.0]),\n  SoftRock: makeBands([4.0, 4.0, 2.4, -1.11022e-15, -4.0, -5.6, -3.2, -1.11022e-15, 2.4, 8.8]),\n  Techno: makeBands([8.0, 5.6, -1.11022e-15, -5.6, -4.8, -1.11022e-15, 8.0, 9.6, 9.6, 8.8])\n});\n\nexport class FFmpegFilterer<Meta = unknown> {\n  #ffmpegFilters: Filters[] = [];\n  #inputArgs: string[] = [];\n  public constructor(public af: GuildQueueAudioFilters<Meta>) {}\n\n  /**\n   * Indicates whether ffmpeg may be skipped\n   */\n  public get skippable() {\n    return !!this.af.queue.player.options.skipFFmpeg;\n  }\n\n  #setFilters(filters: Filters[]) {\n    const { queue } = this.af;\n    // skip if filters are the same\n    if (filters.every((f) => this.#ffmpegFilters.includes(f)) && this.#ffmpegFilters.every((f) => filters.includes(f)))\n    return Promise.resolve(false);\n    const ignoreFilters =\n    this.filters.some((ff) => ff === 'nightcore' || ff === 'vaporwave') &&\n    !filters.some((ff) => ff === 'nightcore' || ff === 'vaporwave');\n    const seekTime = queue.node.getTimestamp(ignoreFilters)?.current.value || 0;\n    const prev = this.#ffmpegFilters.slice();\n    this.#ffmpegFilters = [...new Set(filters)];\n\n    return this.af.triggerReplay(seekTime).then((t) => {\n      queue.emit(GuildQueueEvent.AudioFiltersUpdate, queue, prev, this.#ffmpegFilters.slice());\n      return t;\n    });\n  }\n\n  /**\n   * Set input args for FFmpeg\n   */\n  public setInputArgs(args: string[]) {\n    if (!args.every((arg) => typeof arg === 'string'))\n    throw new InvalidArgTypeError('args', 'Array<string>', 'invalid item(s)');\n    this.#inputArgs = args;\n  }\n\n  /**\n   * Get input args\n   */\n  public get inputArgs() {\n    return this.#inputArgs;\n  }\n\n  /**\n   * Get encoder args\n   */\n  public get encoderArgs() {\n    if (!this.filters.length) return [];\n\n    return ['-af', this.toString()];\n  }\n\n  /**\n   * Get final ffmpeg args\n   */\n  public get args() {\n    return this.inputArgs.concat(this.encoderArgs);\n  }\n\n  /**\n   * Create ffmpeg stream\n   * @param source The stream source\n   * @param options The stream options\n   */\n  public createStream(source: string | Readable, options: FFmpegStreamOptions) {\n    if (this.#inputArgs.length) options.encoderArgs = [...this.#inputArgs, ...(options.encoderArgs || [])];\n    return createFFmpegStream(source, options);\n  }\n\n  /**\n   * Set ffmpeg filters\n   * @param filters The filters\n   */\n  public setFilters(filters: Filters[] | Record<Filters, boolean> | string[] | boolean) {\n    let _filters: Filters[] = [];\n    if (typeof filters === 'boolean') {\n      _filters = !filters ? [] : Object.keys(AudioFilters.filters) as Filters[];\n    } else if (Array.isArray(filters)) {\n      _filters = filters as Filters[];\n    } else {\n      _filters = Object.entries(filters).\n      filter((res) => res[1] === true).\n      map((m) => m[0]) as Filters[];\n    }\n\n    return this.#setFilters(_filters);\n  }\n\n  /**\n   * Currently active ffmpeg filters\n   */\n  public get filters() {\n    return this.#ffmpegFilters;\n  }\n\n  public set filters(filters: Filters[]) {\n    this.setFilters(filters);\n  }\n\n  /**\n   * Toggle given ffmpeg filter(s)\n   * @param filters The filter(s)\n   */\n  public toggle(filters: Filters[] | Filters) {\n    if (!Array.isArray(filters)) filters = [filters];\n    const fresh: Filters[] = [];\n\n    filters.forEach((f) => {\n      if (this.filters.includes(f)) return;\n      fresh.push(f);\n    });\n\n    return this.#setFilters(this.#ffmpegFilters.filter((r) => !filters.includes(r)).concat(fresh));\n  }\n\n  /**\n   * Set default filters\n   * @param ff Filters list\n   */\n  public setDefaults(ff: Filters[]) {\n    this.#ffmpegFilters = ff;\n  }\n\n  /**\n   * Get list of enabled filters\n   */\n  public getFiltersEnabled() {\n    return this.#ffmpegFilters;\n  }\n\n  /**\n   * Get list of disabled filters\n   */\n  public getFiltersDisabled() {\n    return AudioFilters.names.filter((f) => !this.#ffmpegFilters.includes(f));\n  }\n\n  /**\n   * Check if the given filter is enabled\n   * @param filter The filter\n   */\n  public isEnabled<T extends Filters>(filter: T): boolean {\n    return this.#ffmpegFilters.includes(filter);\n  }\n\n  /**\n   * Check if the given filter is disabled\n   * @param filter The filter\n   */\n  public isDisabled<T extends Filters>(filter: T): boolean {\n    return !this.isEnabled(filter);\n  }\n\n  /**\n   * Check if the given filter is a valid filter\n   * @param filter The filter to test\n   */\n  public isValidFilter(filter: string): filter is FiltersName {\n    return AudioFilters.has(filter as Filters);\n  }\n\n  /**\n   * Convert current filters to array\n   */\n  public toArray() {\n    return this.filters.map((filter) => AudioFilters.get(filter));\n  }\n\n  /**\n   * Convert current filters to JSON object\n   */\n  public toJSON() {\n    const obj = {} as Record<keyof QueueFilters, string>;\n\n    this.filters.forEach((filter) => obj[filter] = AudioFilters.get(filter));\n\n    return obj;\n  }\n\n  /**\n   * String representation of current filters\n   */\n  public toString() {\n    return AudioFilters.create(this.filters);\n  }\n}\n\nexport interface GuildQueueAFiltersCache {\n  equalizer: EqualizerBand[];\n  biquad: BiquadFilters | null;\n  filters: PCMFilters[];\n  volume: number;\n  sampleRate: number;\n}\n\nexport class GuildQueueAudioFilters<Meta = unknown> {\n  public graph = new AFilterGraph<Meta>(this);\n  public ffmpeg = new FFmpegFilterer<Meta>(this);\n  public equalizerPresets = EqualizerConfigurationPreset;\n  public _lastFiltersCache: GuildQueueAFiltersCache = {\n    biquad: null,\n    equalizer: [],\n    filters: [],\n    volume: 100,\n    sampleRate: -1\n  };\n  public constructor(public queue: GuildQueue<Meta>) {\n    if (typeof this.queue.options.volume === 'number') {\n      this._lastFiltersCache.volume = this.queue.options.volume;\n    }\n  }\n\n  // TODO: enable this in the future\n  // public get ffmpeg(): FFmpegFilterer<Meta> | null {\n  //     if (this.queue.player.options.skipFFmpeg) {\n  //         if (this.#ffmpeg) this.#ffmpeg = null;\n  //         return null;\n  //     }\n\n  //     if (!this.#ffmpeg) {\n  //         this.#ffmpeg = new FFmpegFilterer<Meta>(this);\n  //     }\n\n  //     return this.#ffmpeg;\n  // }\n\n  /**\n   * Volume transformer\n   */\n  public get volume() {\n    return this.queue.dispatcher?.dsp?.volume || null;\n  }\n\n  /**\n   * 15 Band Equalizer\n   */\n  public get equalizer() {\n    return this.queue.dispatcher?.equalizer || null;\n  }\n\n  /**\n   * Digital biquad filters\n   */\n  public get biquad() {\n    return this.queue.dispatcher?.biquad || null;\n  }\n\n  /**\n   * DSP filters\n   */\n  public get filters() {\n    return this.queue.dispatcher?.filters || null;\n  }\n\n  /**\n   * Audio resampler\n   */\n  public get resampler() {\n    return this.queue.dispatcher?.resampler || null;\n  }\n\n  /**\n   * Replay current track in transition mode\n   * @param seek The duration to seek to\n   */\n  public async triggerReplay(seek = 0) {\n    if (!this.queue.currentTrack) return false;\n    const entry = this.queue.node.tasksQueue.acquire();\n    try {\n      await entry.getTask();\n      await this.queue.node.play(this.queue.currentTrack, {\n        queue: false,\n        seek,\n        transitionMode: true\n      });\n      this.queue.node.tasksQueue.release();\n      return true;\n    } catch {\n      this.queue.node.tasksQueue.release();\n      return false;\n    }\n  }\n}\n\nexport class AFilterGraph<Meta = unknown> {\n  public constructor(public af: GuildQueueAudioFilters<Meta>) {}\n\n  public get ffmpeg() {\n    return this.af.ffmpeg?.filters ?? [];\n  }\n\n  public get equalizer() {\n    return (this.af.equalizer?.bandMultipliers || []).map((m, i) => ({\n      band: i,\n      gain: m\n    })) as EqualizerBand[];\n  }\n\n  public get biquad() {\n    return this.af.biquad?.getFilterName() as Exclude<BiquadFilters, number> | null || null;\n  }\n\n  public get filters() {\n    return this.af.filters?.filters || [];\n  }\n\n  public get volume() {\n    return this.af.volume;\n  }\n\n  public get resampler() {\n    return this.af.resampler;\n  }\n\n  public dump(): FilterGraph {\n    return {\n      ffmpeg: this.ffmpeg,\n      equalizer: this.equalizer,\n      biquad: this.biquad,\n      filters: this.filters,\n      sampleRate: this.resampler?.targetSampleRate || this.resampler?.sampleRate || 48000,\n      volume: this.volume?.volume ?? 100\n    };\n  }\n}\n\nexport interface FilterGraph {\n  ffmpeg: Filters[];\n  equalizer: EqualizerBand[];\n  biquad: Exclude<BiquadFilters, number> | null;\n  filters: PCMFilters[];\n  volume: number;\n  sampleRate: number;\n}", "import type { Duplex, Readable } from 'stream';\nimport { FFmpeg } from '@discord-player/ffmpeg';\n\nexport interface FFmpegStreamOptions {\n  fmt?: string;\n  encoderArgs?: string[];\n  seek?: number;\n  skip?: boolean;\n  cookies?: string;\n}\n\nconst resolveArgs = (config: Record<string, string | number | null | undefined>): string[] => {\n  return Object.entries(config).reduce((acc, [key, value]) => {\n    if (value == null) return acc;\n    acc.push(`-${key}`, String(value));\n    return acc;\n  }, [] as string[]);\n};\n\nexport function FFMPEG_ARGS_STRING(stream: string, fmt?: string, cookies?: string) {\n  const args = resolveArgs({\n    reconnect: 1,\n    reconnect_streamed: 1,\n    reconnect_delay_max: 5,\n    i: stream,\n    analyzeduration: 0,\n    loglevel: 0,\n    ar: 48000,\n    ac: 2,\n    f: `${typeof fmt === 'string' ? fmt : 's16le'}`,\n    acodec: fmt === 'opus' ? 'libopus' : null,\n    cookies: typeof cookies === 'string' ? !cookies.includes(' ') ? cookies : `\"${cookies}\"` : null\n  });\n\n  return args;\n}\n\nexport function FFMPEG_ARGS_PIPED(fmt?: string) {\n  const args = resolveArgs({\n    analyzeduration: 0,\n    loglevel: 0,\n    ar: 48000,\n    ac: 2,\n    f: `${typeof fmt === 'string' ? fmt : 's16le'}`,\n    acodec: fmt === 'opus' ? 'libopus' : null\n  });\n\n  return args;\n}\n\n/**\n * Creates FFmpeg stream\n * @param stream The source stream\n * @param options FFmpeg stream options\n */\nexport function createFFmpegStream(stream: Readable | Duplex | string, options?: FFmpegStreamOptions) {\n  if (options?.skip && typeof stream !== 'string') return stream;\n  options ??= {};\n  const args =\n  typeof stream === 'string' ?\n  FFMPEG_ARGS_STRING(stream, options.fmt, options.cookies) :\n  FFMPEG_ARGS_PIPED(options.fmt);\n\n  if (!Number.isNaN(options.seek)) args.unshift('-ss', String(options.seek));\n  if (Array.isArray(options.encoderArgs)) args.push(...options.encoderArgs);\n\n  const transcoder: Duplex = new FFmpeg({ shell: false, args });\n\n  transcoder.on('close', () => transcoder.destroy());\n\n  if (typeof stream !== 'string') {\n    stream.on('error', () => transcoder.destroy());\n    // eslint-disable-next-line @typescript-eslint/no-explicit-any\n    stream.pipe(transcoder as any);\n  }\n\n  return transcoder;\n}", "import { GuildQueue } from './GuildQueue';\n\nexport interface GuildQueueStatisticsMetadata {\n  latency: {\n    eventLoop: number;\n    voiceConnection: number;\n  };\n  status: {\n    buffering: boolean;\n    playing: boolean;\n    paused: boolean;\n    idle: boolean;\n  };\n  tracksCount: number;\n  historySize: number;\n  extractors: number;\n  listeners: number;\n  memoryUsage: NodeJS.MemoryUsage;\n  versions: {\n    node: string;\n    player: string;\n  };\n}\n\nexport class GuildQueueStatistics<Meta = unknown> {\n  public constructor(public queue: GuildQueue<Meta>) {}\n\n  /**\n   * Generate statistics of this queue\n   */\n  public generate() {\n    return {\n      latency: {\n        eventLoop: this.queue.player.eventLoopLag,\n        voiceConnection: this.queue.ping\n      },\n      status: {\n        buffering: this.queue.node.isBuffering(),\n        playing: this.queue.node.isPlaying(),\n        paused: this.queue.node.isPaused(),\n        idle: this.queue.node.isIdle()\n      },\n      tracksCount: this.queue.tracks.size,\n      historySize: this.queue.history.tracks.size,\n      extractors: this.queue.player.extractors.size,\n      listeners: this.queue.guild.members.me?.voice.channel?.members.filter((m) => !m.user.bot).size || 0,\n      memoryUsage: process.memoryUsage(),\n      versions: {\n        node: process.version,\n        player: this.queue.player.version\n      }\n    } as GuildQueueStatisticsMetadata;\n  }\n}", "import { NotExistingError } from '../errors';\nimport { LrcGetResult, LrcSearchResult } from '../lrclib/LrcLib';\nimport type { GuildQueue } from './GuildQueue';\n\nexport type LyricsData = Map<number, string>;\nexport type Unsubscribe = () => void;\nexport type LyricsCallback = (lyrics: string, timestamp: number) => unknown;\nexport type LyricsAt = {timestamp: number;line: string;};\n\nconst timestampPattern = /\\[(\\d{2}):(\\d{2})\\.(\\d{2})\\]/;\n\nexport class SyncedLyricsProvider {\n  #loop: NodeJS.Timeout | null = null;\n  #callback: LyricsCallback | null = null;\n  #onUnsubscribe: Unsubscribe | null = null;\n\n  public interval = 100;\n  public readonly lyrics: LyricsData = new Map();\n\n  public constructor(public readonly queue: GuildQueue, public readonly raw?: LrcGetResult | LrcSearchResult) {\n    if (raw?.syncedLyrics) this.load(raw?.syncedLyrics);\n  }\n\n  public isSubscribed() {\n    return this.#callback !== null;\n  }\n\n  public load(lyrics: string) {\n    if (!lyrics) throw new NotExistingError('syncedLyrics');\n\n    this.lyrics.clear();\n    this.unsubscribe();\n\n    const lines = lyrics.split('\\n');\n\n    for (const line of lines) {\n      const match = line.match(timestampPattern);\n\n      if (match) {\n        const [, minutes, seconds, milliseconds] = match;\n        const timestamp = parseInt(minutes) * 60 * 1000 + parseInt(seconds) * 1000 + parseInt(milliseconds);\n\n        this.lyrics.set(timestamp, line.replace(timestampPattern, '').trim());\n      }\n    }\n  }\n\n  /**\n   * Returns the lyrics at a specific time or at the closest time (\u00B12 seconds)\n   * @param time The time in milliseconds\n   */\n  public at(time: number): LyricsAt | null {\n    const lowestTime = this.lyrics.keys().next().value;\n    if (lowestTime == null || time < lowestTime) return null;\n    if (this.lyrics.has(time)) return { line: this.lyrics.get(time) as string, timestamp: time };\n\n    const keys = Array.from(this.lyrics.keys());\n\n    const closest = keys.reduce((a, b) => Math.abs(b - time) < Math.abs(a - time) ? b : a);\n\n    if (closest > time) return null;\n\n    if (Math.abs(closest - time) > 2000) return null;\n\n    const line = this.lyrics.get(closest);\n\n    if (!line) return null;\n\n    return { timestamp: closest, line };\n  }\n\n  /**\n   * Callback for the lyrics change.\n   * @param callback The callback function\n   */\n  public onChange(callback: LyricsCallback) {\n    this.#callback = callback;\n  }\n\n  /**\n   * Callback to detect when the provider is unsubscribed.\n   * @param callback The callback function\n   */\n  public onUnsubscribe(callback: Unsubscribe) {\n    this.#onUnsubscribe = callback;\n  }\n\n  /**\n   * Unsubscribes from the queue.\n   */\n  public unsubscribe() {\n    if (this.#loop) clearInterval(this.#loop);\n    if (this.#onUnsubscribe) this.#onUnsubscribe();\n\n    this.#callback = null;\n    this.#onUnsubscribe = null;\n    this.#loop = null;\n  }\n\n  /**\n   * Subscribes to the queue to monitor the current time.\n   * @returns The unsubscribe function\n   */\n  public subscribe(): Unsubscribe {\n    if (this.#loop) return () => this.unsubscribe();\n\n    this.#createLoop();\n\n    return () => this.unsubscribe();\n  }\n\n  /**\n   * Pauses the lyrics provider.\n   */\n  public pause() {\n    const hasLoop = this.#loop !== null;\n\n    if (hasLoop) {\n      clearInterval(this.#loop!);\n      this.#loop = null;\n    }\n\n    return hasLoop;\n  }\n\n  /**\n   * Resumes the lyrics provider.\n   */\n  public resume() {\n    const hasLoop = this.#loop !== null;\n\n    if (!hasLoop) this.#createLoop();\n\n    return !hasLoop;\n  }\n\n  #createLoop() {\n    if (!this.#callback) return;\n    if (this.#loop) clearInterval(this.#loop);\n\n    let lastValue: LyricsAt | null = null;\n\n    this.#loop = setInterval(() => {\n      if (this.queue.deleted) return this.unsubscribe();\n\n      if (!this.#callback || !this.queue.isPlaying()) return;\n\n      const time = this.queue.node.getTimestamp();\n      if (!time) return;\n\n      const lyrics = this.at(time.current.value);\n\n      if (!lyrics) return;\n\n      if (lastValue !== null && lyrics.line === lastValue.line && lyrics.timestamp === lastValue.timestamp) return;\n\n      lastValue = lyrics;\n\n      this.#callback(lyrics.line, lyrics.timestamp);\n    }, this.interval).unref();\n  }\n}", "import { setTimeout } from 'timers/promises';\nimport { AsyncQueue } from './AsyncQueue';\n\nexport type RequestEntity = () => Promise<Response>;\n\nexport class SequentialBucket {\n  public limit = 1;\n  public remaining = 1;\n  public resetAfter = 0;\n  public queue = new AsyncQueue();\n  public MAX_RETRIES = 5;\n\n  /**\n   * Checks if the bucket is rate limited.\n   */\n  public isRateLimited() {\n    return this.remaining <= 0 && Date.now() < this.resetAfter;\n  }\n\n  /**\n   * Enqueues a request.\n   * @param req The request function to enqueue\n   */\n  public async enqueue(req: RequestEntity) {\n    const entry = this.queue.acquire();\n    await entry.getTask();\n\n    try {\n      return this._request(req);\n    } finally {\n      entry.release();\n    }\n  }\n\n  private async _request(req: RequestEntity, retries = 0): Promise<Response> {\n    while (this.isRateLimited()) {\n      const reset = this.resetAfter - Date.now();\n      await setTimeout(reset);\n    }\n\n    let pass = false;\n\n    try {\n      const res = await req();\n\n      this._patchHeaders(res);\n\n      if (res.status === 429) {\n        const reset = this.resetAfter - Date.now();\n        await setTimeout(reset);\n        return this._request(req);\n      }\n\n      if (!res.ok) {\n        let err: Error;\n\n        try {\n          const body: {\n            code: number;\n            name: string;\n            message: string;\n          } = await res.json();\n\n          const error = new Error(body.message) as Error & {code: number;};\n\n          error.name = body.name;\n          error.code = body.code;\n\n          err = error;\n        } catch {\n          err = new Error(`HTTP Error: ${res.status} ${res.statusText}`);\n        }\n\n        pass = true;\n\n        throw err;\n      }\n\n      return res;\n    } catch (e) {\n      if (pass) throw e;\n\n      const badReq = e instanceof Error && /Error: 4[0-9]{2}/.test(e.message);\n\n      if (!badReq && retries < this.MAX_RETRIES) {\n        return this._request(req, ++retries);\n      }\n\n      throw e;\n    }\n  }\n\n  private _patchHeaders(res: Response) {\n    const limit = Number(res.headers.get('X-RateLimit-Limit'));\n    const remaining = Number(res.headers.get('X-RateLimit-Remaining'));\n    const resetAfter = Number(res.headers.get('X-RateLimit-Reset')) * 1000 + Date.now();\n\n    if (!Number.isNaN(limit)) this.limit = limit;\n    if (!Number.isNaN(remaining)) this.remaining = remaining;\n    if (!Number.isNaN(resetAfter)) this.resetAfter = resetAfter;\n  }\n}", "import { InvalidArgTypeError } from '../errors';\nimport type { Player } from '../Player';\nimport { Util } from '../utils/Util';\nimport { SequentialBucket } from '../utils/SequentialBucket';\n\nexport interface LrcSearchParams {\n  /**\n   * The query to search for. Either this or trackName is required.\n   */\n  q?: string;\n  /**\n   * The track name to search for. Either this or query is required.\n   */\n  trackName?: string;\n  /**\n   * The artist name\n   */\n  artistName?: string;\n  /**\n   * The album name\n   */\n  albumName?: string;\n}\n\nexport interface LrcGetParams extends Required<Omit<LrcSearchParams, 'query'>> {\n  /**\n   * The duration of the track\n   */\n  duration: number;\n}\n\nconst toSnakeCase = (obj: Record<string, string>): Record<string, string> => {\n  const snakeObj: Record<string, string> = {};\n\n  for (const [key, value] of Object.entries(obj)) {\n    if (value == null) continue;\n    const newKey = key.replace(/[A-Z]/g, (letter) => `_${letter.toLowerCase()}`);\n    snakeObj[newKey] = value;\n  }\n\n  return snakeObj;\n};\n\n// eslint-disable-next-line @typescript-eslint/no-explicit-any\nconst createQuery = (params: any) => new URLSearchParams(toSnakeCase(params)).toString();\n\nexport interface LrcSearchResult {\n  /**\n   * The track id\n   */\n  id: number;\n  /**\n   * The track name\n   */\n  name: string;\n  /**\n   * The artist name\n   */\n  trackName: string;\n  /**\n   * The album name\n   */\n  artistName: string;\n  /**\n   * The album name\n   */\n  albumName: string;\n  /**\n   * The duration of the track\n   */\n  duration: number;\n  /**\n   * The release date of the track\n   */\n  instrumental: boolean;\n  /**\n   * The release date of the track\n   */\n  plainLyrics: string;\n  /**\n   * The release date of the track\n   */\n  syncedLyrics?: string;\n}\n\nexport type LrcGetResult = Omit<LrcSearchResult, 'name'>;\n\nexport class LrcLib {\n  /**\n   * The API URL\n   */\n  public api = 'https://lrclib.net/api';\n  /**\n   * The request timeout. Default is 15 seconds.\n   */\n  public timeout = 15_000;\n  /**\n   * The request bucket\n   */\n  public bucket = new SequentialBucket();\n\n  /**\n   * Creates a new LrcLib instance\n   * @param {Player} player The player instance\n   */\n  public constructor(public readonly player: Player) {}\n\n  /**\n   * Sets the request timeout\n   * @param {number} timeout The timeout in milliseconds\n   */\n  public setRequestTimeout(timeout: number) {\n    this.timeout = timeout;\n  }\n\n  /**\n   * Sets the retry limit. Default is 5.\n   * @param {number} limit The retry limit\n   */\n  public setRetryLimit(limit: number) {\n    this.bucket.MAX_RETRIES = limit;\n  }\n\n  /**\n   * Gets lyrics\n   * @param params The get params\n   */\n  public get(params: LrcGetParams) {\n    const path = `get?${createQuery(params)}`;\n\n    return this.request<LrcSearchResult>(path);\n  }\n\n  /**\n   * Gets lyrics by ID\n   * @param id The lyrics ID\n   */\n  public getById(id: `${number}` | number) {\n    return this.request<LrcSearchResult>(`get/${id}`);\n  }\n\n  /**\n   * Gets cached lyrics\n   * @param params The get params\n   */\n  public getCached(params: LrcGetParams) {\n    const path = `get-cached?${createQuery(params)}`;\n\n    return this.request<LrcSearchResult>(path);\n  }\n\n  /**\n   * Searches for lyrics\n   * @param params The search params\n   */\n  public search(params: LrcSearchParams) {\n    if (!params.q && !params.trackName) {\n      throw new InvalidArgTypeError(\n        'one of q or trackName',\n        'string',\n        [String(params.q), String(params.trackName)].join(', ')\n      );\n    }\n\n    const path = `search?${createQuery(params)}`;\n\n    return this.request<LrcSearchResult[]>(path);\n  }\n\n  /**\n   * Requests the API\n   * @param path The path\n   * @param options The request options\n   */\n  public async request<T>(path: string, options?: RequestInit): Promise<T> {\n    const dispatcher = () => {\n      const { name, version } = Util.getRuntime();\n\n      const runtimeVersion = name === 'unknown' ? version : `${name}/${version}`;\n\n      const init: RequestInit = {\n        method: 'GET',\n        redirect: 'follow',\n        signal: AbortSignal.timeout(this.timeout),\n        ...options,\n        headers: {\n          'User-Agent': `Discord-Player/${this.player.version} ${runtimeVersion ?? ''}`.trimEnd(),\n          'Content-Type': 'application/json',\n          ...options?.headers\n        }\n      };\n\n      this.player.debug(`[LrcLib] Requesting ${path}`);\n\n      return fetch(`${this.api}${path.startsWith('/') ? path : '/' + path}`, init);\n    };\n\n    const res = await this.bucket.enqueue(dispatcher);\n\n    return res.json();\n  }\n}", "import { VoiceChannel, StageChannel, Snowflake } from 'discord.js';\nimport {\n  DiscordGatewayAdapterCreator,\n  joinVoiceChannel,\n  VoiceConnection,\n  getVoiceConnection,\n  VoiceConnectionStatus,\n  AudioPlayer } from\n'discord-voip';\nimport { StreamDispatcher } from './StreamDispatcher';\nimport { Collection } from '@discord-player/utils';\nimport { GuildQueue } from '../queue';\nimport type { Player } from '../Player';\nimport { NoGuildQueueError } from '../errors';\n\nclass VoiceUtils {\n  /**\n   * Voice connection cache to store voice connections of the Player components.\n   * This property is deprecated and will be removed in the future.\n   * It only exists for compatibility reasons.\n   * @deprecated\n   */\n  public cache: Collection<Snowflake, StreamDispatcher> = new Collection<Snowflake, StreamDispatcher>();\n\n  /**\n   * The voice utils constructor\n   */\n  constructor(public player: Player) {}\n\n  /**\n   * Joins a voice channel, creating basic stream dispatch manager\n   * @param {StageChannel|VoiceChannel} channel The voice channel\n   * @param {object} [options] Join options\n   * @returns {Promise<StreamDispatcher>}\n   */\n  public async connect(\n  channel: VoiceChannel | StageChannel,\n  options?: {\n    deaf?: boolean;\n    maxTime?: number;\n    queue: GuildQueue;\n    audioPlayer?: AudioPlayer;\n    group?: string;\n  })\n  : Promise<StreamDispatcher> {\n    if (!options?.queue) throw new NoGuildQueueError();\n    const conn = await this.join(channel, options);\n    const sub = new StreamDispatcher(conn, channel, options.queue, options.maxTime, options.audioPlayer);\n    return sub;\n  }\n\n  /**\n   * Joins a voice channel\n   * @param {StageChannel|VoiceChannel} [channel] The voice/stage channel to join\n   * @param {object} [options] Join options\n   * @returns {VoiceConnection}\n   */\n  public async join(\n  channel: VoiceChannel | StageChannel,\n  options?: {\n    deaf?: boolean;\n    maxTime?: number;\n    group?: string;\n  })\n  {\n    const existingConnection = this.getConnection(channel.guild.id, options?.group);\n\n    if (\n    existingConnection?.joinConfig.channelId === channel?.id &&\n    existingConnection.state.status !== VoiceConnectionStatus.Destroyed)\n    {\n      return existingConnection;\n    }\n\n    const conn = joinVoiceChannel({\n      guildId: channel.guild.id,\n      channelId: channel.id,\n      adapterCreator: channel.guild.voiceAdapterCreator as unknown as DiscordGatewayAdapterCreator,\n      selfDeaf: Boolean(options?.deaf),\n      debug: this.player.events.listenerCount('debug') > 0,\n      group: options?.group\n    });\n\n    return conn;\n  }\n\n  /**\n   * Disconnects voice connection\n   * @param {VoiceConnection} connection The voice connection\n   * @returns {void}\n   */\n  public disconnect(connection: VoiceConnection | StreamDispatcher) {\n    if (connection instanceof StreamDispatcher) connection = connection.voiceConnection;\n\n    try {\n      if (connection.state.status !== VoiceConnectionStatus.Destroyed) return connection.destroy();\n    } catch {\n\n      //\n    }}\n\n  /**\n   * Returns Discord Player voice connection\n   * @param {Snowflake} guild The guild id\n   * @returns {StreamDispatcher}\n   */\n  public getConnection(guild: Snowflake, group?: string) {\n    return getVoiceConnection(guild, group);\n  }\n}\n\nexport { VoiceUtils };", "import { Player } from '../Player';\nimport { SearchResult } from '../fabric/SearchResult';\nimport { Track } from '../fabric/Track';\nimport { User } from 'discord.js';\nimport { SearchQueryType } from './QueryResolver';\n\nexport interface QueryCacheOptions {\n  checkInterval?: number;\n}\n\n// 5h\nconst DEFAULT_EXPIRY_TIMEOUT = 18_000_000;\n\nexport interface QueryCacheProvider<T> {\n  getData(): Promise<DiscordPlayerQueryResultCache<T>[]>;\n  addData(data: SearchResult): Promise<void>;\n  resolve(context: QueryCacheResolverContext): Promise<SearchResult>;\n}\n\nexport class QueryCache implements QueryCacheProvider<Track> {\n  #defaultCache = new Map<string, DiscordPlayerQueryResultCache<Track>>();\n  public timer: NodeJS.Timer;\n  public constructor(\n  public player: Player,\n  public options: QueryCacheOptions = {\n    checkInterval: DEFAULT_EXPIRY_TIMEOUT\n  })\n  {\n    this.timer = setInterval(this.cleanup.bind(this), this.checkInterval).unref();\n  }\n\n  public get checkInterval() {\n    return this.options.checkInterval ?? DEFAULT_EXPIRY_TIMEOUT;\n  }\n\n  public async cleanup() {\n    for (const [id, value] of this.#defaultCache) {\n      if (value.hasExpired()) {\n        this.#defaultCache.delete(id);\n      }\n    }\n  }\n\n  public async clear() {\n    this.#defaultCache.clear();\n  }\n\n  public async getData() {\n    return [...this.#defaultCache.values()];\n  }\n\n  public async addData(data: SearchResult) {\n    data.tracks.forEach((d) => {\n      if (this.#defaultCache.has(d.url)) return;\n      this.#defaultCache.set(d.url, new DiscordPlayerQueryResultCache(d));\n    });\n  }\n\n  public async resolve(context: QueryCacheResolverContext) {\n    const result = this.#defaultCache.get(context.query);\n    if (!result)\n    return new SearchResult(this.player, {\n      query: context.query,\n      requestedBy: context.requestedBy,\n      queryType: context.queryType\n    });\n\n    return new SearchResult(this.player, {\n      query: context.query,\n      tracks: [result.data],\n      playlist: null,\n      queryType: context.queryType,\n      requestedBy: context.requestedBy\n    });\n  }\n}\n\nexport class DiscordPlayerQueryResultCache<T = unknown> {\n  public expireAfter = DEFAULT_EXPIRY_TIMEOUT;\n  public constructor(public data: T, expireAfter: number = DEFAULT_EXPIRY_TIMEOUT) {\n    if (typeof expireAfter === 'number') {\n      this.expireAfter = Date.now() + expireAfter;\n    }\n  }\n\n  public hasExpired() {\n    if (typeof this.expireAfter !== 'number' || isNaN(this.expireAfter) || this.expireAfter < 1) return false;\n    return Date.now() <= this.expireAfter;\n  }\n}\n\nexport interface QueryCacheResolverContext {\n  query: string;\n  requestedBy?: User;\n  queryType?: SearchQueryType | `ext:${string}`;\n}", "import { FFmpeg } from '@discord-player/ffmpeg';\nimport {\n  Client,\n  SnowflakeUtil,\n  VoiceState,\n  IntentsBitField,\n  User,\n  GuildVoiceChannelResolvable,\n  version as djsVersion,\n  Events } from\n'discord.js';\nimport { Playlist, Track, SearchResult, SearchOptions, PlaylistInitData } from './fabric';\nimport {\n  GuildQueueEvents,\n  VoiceConnectConfig,\n  GuildNodeCreateOptions,\n  GuildNodeManager,\n  GuildQueue,\n  ResourcePlayOptions,\n  GuildQueueEvent } from\n'./queue';\nimport { VoiceUtils } from './stream/VoiceUtils';\nimport { QueryResolver, QueryType, ResolvedQuery, SearchQueryType } from './utils/QueryResolver';\nimport { Util } from './utils/Util';\nimport { AudioResource, version as dVoiceVersion } from 'discord-voip';\nimport { ExtractorExecutionContext } from './extractors/ExtractorExecutionContext';\nimport { BaseExtractor } from './extractors/BaseExtractor';\nimport { QueryCache, QueryCacheProvider } from './utils/QueryCache';\nimport { PlayerEventsEmitter } from './utils/PlayerEventsEmitter';\nimport { InvalidArgTypeError, NoResultError } from './errors';\nimport { defaultVoiceStateHandler } from './DefaultVoiceStateHandler';\nimport { Context, createContext } from './hooks';\nimport { HooksCtx, SUPER_CONTEXT } from './hooks/common';\nimport { LrcLib } from './lrclib/LrcLib';\nimport { getCompatName, isClientProxy } from './compat/createErisCompat';\nimport { DependencyReportGenerator } from './utils/DependencyReportGenerator';\nimport { getGlobalRegistry } from './utils/__internal__';\nimport { version as dpVersion } from './version';\n\n/* eslint-disable @typescript-eslint/no-explicit-any */\nexport interface PlayerEvents {\n  debug: (message: string) => any;\n  error: (error: Error) => any;\n  voiceStateUpdate: (queue: GuildQueue, oldState: VoiceState, newState: VoiceState) => any;\n}\n\nexport const PlayerEvent = {\n  debug: 'debug',\n  Debug: 'debug',\n  error: 'error',\n  Error: 'error',\n  voiceStateUpdate: 'voiceStateUpdate',\n  VoiceStateUpdate: 'voiceStateUpdate'\n} as const;\nexport type PlayerEvent = (typeof PlayerEvent)[keyof typeof PlayerEvent];\n\n/* eslint-enable @typescript-eslint/no-explicit-any */\n\nexport interface PlayerNodeInitializationResult<T = unknown> {\n  track: Track;\n  extractor: BaseExtractor | null;\n  searchResult: SearchResult;\n  queue: GuildQueue<T>;\n}\n\nexport type TrackLike = string | Track | SearchResult | Track[] | Playlist | AudioResource;\n\nexport interface PlayerNodeInitializerOptions<T> extends SearchOptions {\n  nodeOptions?: GuildNodeCreateOptions<T>;\n  connectionOptions?: VoiceConnectConfig;\n  audioPlayerOptions?: ResourcePlayOptions;\n  signal?: AbortSignal;\n  afterSearch?: (result: SearchResult) => Promise<SearchResult>;\n}\n\nexport type VoiceStateHandler = (\nplayer: Player,\nqueue: GuildQueue,\noldVoiceState: VoiceState,\nnewVoiceState: VoiceState)\n=> Awaited<void>;\n\nexport interface PlayerInitOptions {\n  /**\n   * The voice connection timeout\n   */\n  connectionTimeout?: number;\n  /**\n   * Time in ms to re-monitor event loop lag\n   */\n  lagMonitor?: number;\n  /**\n   * Prevent voice state handler from being overridden\n   */\n  lockVoiceStateHandler?: boolean;\n  /**\n   * List of extractors to disable querying metadata from\n   */\n  blockExtractors?: string[];\n  /**\n   * List of extractors to disable streaming from\n   */\n  blockStreamFrom?: string[];\n  /**\n   * Query cache provider\n   */\n  // eslint-disable-next-line @typescript-eslint/no-explicit-any\n  queryCache?: QueryCacheProvider<any> | null;\n  /**\n   * Skip ffmpeg process when possible\n   */\n  skipFFmpeg?: boolean;\n  /**\n   * The probe timeout in milliseconds. Defaults to 5000.\n   */\n  probeTimeout?: number;\n  /**\n   * Configure ffmpeg path\n   */\n  ffmpegPath?: string;\n  /**\n   * Whether to override the fallback context. Defaults to `true`.\n   */\n  overrideFallbackContext?: boolean;\n}\n\nexport class Player extends PlayerEventsEmitter<PlayerEvents> {\n  #lastLatency = -1;\n  #voiceStateUpdateListener = this.handleVoiceState.bind(this);\n  #lagMonitorTimeout: NodeJS.Timeout;\n  #lagMonitorInterval: NodeJS.Timeout;\n  #onVoiceStateUpdate: VoiceStateHandler = defaultVoiceStateHandler;\n  #hooksCtx: Context<HooksCtx> | null = null;\n  /**\n   * The version of discord-player\n   */\n  public static readonly version: string = dpVersion;\n  /**\n   * The unique identifier of this player instance\n   */\n  public readonly id = SnowflakeUtil.generate().toString();\n  /**\n   * The discord.js client\n   */\n  public readonly client!: Client;\n  /**\n   * The player options\n   */\n  public readonly options!: PlayerInitOptions;\n  /**\n   * The player nodes (queue) manager\n   */\n  public nodes = new GuildNodeManager(this);\n  /**\n   * The voice api utilities\n   */\n  public readonly voiceUtils = new VoiceUtils(this);\n  /**\n   * The extractors manager\n   */\n  public extractors = new ExtractorExecutionContext(this);\n  /**\n   * The player events channel\n   */\n  public events = new PlayerEventsEmitter<GuildQueueEvents>([GuildQueueEvent.Error, GuildQueueEvent.PlayerError]);\n  /**\n   * The player version\n   */\n  public readonly version = Player.version;\n  /**\n   * The lyrics api\n   */\n  public readonly lyrics = new LrcLib(this);\n\n  /**\n   * Creates new Discord Player\n   * @param {Client} client The Discord Client\n   * @param {PlayerInitOptions} [options] The player init options\n   */\n  public constructor(client: Client, options: PlayerInitOptions = {}) {\n    super([PlayerEvent.Error]);\n\n    if (options.ffmpegPath) {\n      if (typeof options.ffmpegPath !== 'string')\n      throw new TypeError(`Expected type \"string\" for options.ffmpegPath. Got ${typeof options.ffmpegPath} instead`);\n\n      process.env.FFMPEG_PATH = options.ffmpegPath;\n    }\n\n    const isCompatMode = isClientProxy(client);\n\n    /**\n     * The discord client\n     * @type {Client}\n     */\n    this.client = client;\n\n    if (!isCompatMode) {\n      try {\n        if (!(client instanceof Client)) {\n          Util.warn(\n            `Client is not an instance of discord.js@${djsVersion} client, some things may not work correctly. This can happen due to corrupt dependencies or having multiple installations of discord.js.`,\n            'InvalidClientInstance'\n          );\n        }\n\n        const ibf =\n        this.client.options.intents instanceof IntentsBitField ?\n        this.client.options.intents :\n        new IntentsBitField(this.client.options.intents);\n\n        if (!ibf.has(IntentsBitField.Flags.GuildVoiceStates)) {\n          Util.warn('client is missing \"GuildVoiceStates\" intent', 'InvalidIntentsBitField');\n        }\n      } catch {\n\n        // noop\n      }}\n\n    this.options = {\n      lockVoiceStateHandler: false,\n      blockExtractors: [],\n      blockStreamFrom: [],\n      connectionTimeout: 20000,\n      lagMonitor: 30000,\n      queryCache: options.queryCache === null ? null : options.queryCache || new QueryCache(this),\n      skipFFmpeg: true,\n      probeTimeout: 5000,\n      overrideFallbackContext: true,\n      ...options\n    } satisfies PlayerInitOptions;\n\n    if (!isCompatMode) {\n      // @ts-ignore private method\n      this.client.incrementMaxListeners();\n      this.client.on(Events.VoiceStateUpdate, this.#voiceStateUpdateListener);\n    } else {\n      try {\n        // @ts-ignore private method\n        this.client.__dp_voiceStateUpdate_proxy(this.#voiceStateUpdateListener);\n      } catch (e) {\n        Util.warn(\n          'Failed to attach voice state update proxy, voice state handler will not work properly',\n          'CompatModeError'\n        );\n      }\n    }\n\n    if (typeof this.options.lagMonitor === 'number' && this.options.lagMonitor > 0) {\n      this.#lagMonitorInterval = setInterval(() => {\n        const start = performance.now();\n        this.#lagMonitorTimeout = setTimeout(() => {\n          this.#lastLatency = performance.now() - start;\n          if (this.hasDebugger) this.debug(`[Lag Monitor] Event loop latency: ${this.#lastLatency}ms`);\n        }, 0).unref();\n      }, this.options.lagMonitor).unref();\n    }\n\n    if (this.options.overrideFallbackContext) {\n      getGlobalRegistry().set('@[player]', this);\n    }\n  }\n\n  /**\n   * The hooks context for this player instance.\n   */\n  public get context() {\n    if (!this.#hooksCtx) {\n      this.#hooksCtx = createContext();\n\n      const originalProvider = this.#hooksCtx.provide.bind(this.#hooksCtx);\n\n      this.#hooksCtx.provide = (value, receiver) => {\n        return SUPER_CONTEXT.provide(this, () => {\n          return originalProvider(value, () => {\n            return receiver();\n          });\n        });\n      };\n    }\n\n    return this.#hooksCtx;\n  }\n\n  /**\n   * Override default voice state update handler\n   * @param handler The handler callback\n   */\n  public onVoiceStateUpdate(handler: VoiceStateHandler) {\n    this.#onVoiceStateUpdate = handler;\n  }\n\n  public debug(m: string) {\n    return this.emit('debug', m);\n  }\n\n  /**\n   * Creates new discord-player instance.\n   * @param client The client that instantiated player\n   * @param options Player initializer options\n   */\n  public static create(client: Client, options: PlayerInitOptions = {}) {\n    return new Player(client, options);\n  }\n\n  /**\n   * The current query cache provider in use\n   */\n  public get queryCache() {\n    return this.options.queryCache ?? null;\n  }\n\n  /**\n   * Alias to `Player.nodes`.\n   */\n  public get queues() {\n    return this.nodes;\n  }\n\n  /**\n   * Event loop latency in ms. If your bot is laggy and this returns a number above 20ms for example,\n   * some expensive task is being executed on the current thread which is slowing down the event loop.\n   * @type {number}\n   */\n  public get eventLoopLag() {\n    return this.#lastLatency;\n  }\n\n  /**\n   * Generates statistics that could be useful. Statistics generator is still experimental.\n   * @example ```typescript\n   * const stats = player.generateStatistics();\n   *\n   * console.log(stats);\n   *\n   * // outputs something like\n   * // {\n   * //   queuesCount: number,\n   * //   queryCacheEnabled: boolean,\n   * //   queues: [\n   * //      GuildQueueStatisticsMetadata,\n   * //      GuildQueueStatisticsMetadata,\n   * //      GuildQueueStatisticsMetadata,\n   * //      ...\n   * //   ]\n   * // }\n   * ```\n   */\n  public generateStatistics() {\n    return {\n      queuesCount: this.queues.cache.size,\n      queryCacheEnabled: this.queryCache != null,\n      queues: this.queues.cache.map((m) => m.stats.generate())\n    };\n  }\n\n  /**\n   * Whether the player is in compatibility mode. Compatibility mode is enabled when non-discord.js client is used.\n   */\n  public isCompatMode() {\n    return isClientProxy(this.client);\n  }\n\n  /**\n   * Destroy every single queues managed by this master player instance\n   * @example ```typescript\n   * // use me when you want to immediately terminate every single queues in existence \uD83D\uDD2A\n   * await player.destroy();\n   * ```\n   */\n  public async destroy() {\n    this.nodes.cache.forEach((node) => node.delete());\n\n    if (!this.isCompatMode()) {\n      this.client.off(Events.VoiceStateUpdate, this.#voiceStateUpdateListener);\n      // @ts-ignore private method\n      this.client.decrementMaxListeners();\n    }\n\n    this.removeAllListeners();\n    this.events.removeAllListeners();\n    await this.extractors.unregisterAll();\n    if (this.#lagMonitorInterval) clearInterval(this.#lagMonitorInterval);\n    if (this.#lagMonitorTimeout) clearInterval(this.#lagMonitorTimeout);\n  }\n\n  private _handleVoiceState(oldState: VoiceState, newState: VoiceState) {\n    const queue = this.nodes.get(oldState.guild.id);\n    if (!queue || !queue.connection || !queue.channel) return;\n\n    // dispatch voice state update\n    const wasHandled = this.events.emit(GuildQueueEvent.VoiceStateUpdate, queue, oldState, newState);\n    // if the event was handled, return assuming the listener implemented all of the logic below\n    if (wasHandled && !this.options.lockVoiceStateHandler) return;\n\n    return this.#onVoiceStateUpdate(this, queue, oldState, newState);\n  }\n\n  /**\n   * Handles voice state update\n   * @param {VoiceState} oldState The old voice state\n   * @param {VoiceState} newState The new voice state\n   * @returns {void}\n   * @example ```typescript\n   * // passing voice state update data to this method will trigger voice state handler\n   *\n   * client.on('voiceStateUpdate', (oldState, newState) => {\n   *   // this is definitely a rocket science, right here\n   *   player.handleVoiceState(oldState, newState);\n   * });\n   * ```\n   */\n  public handleVoiceState(oldState: VoiceState, newState: VoiceState): void {\n    this._handleVoiceState(oldState, newState);\n  }\n\n  /**\n   * Lock voice state handler. When this method is called, discord-player will keep using the default voice state update handler, even if custom implementation exists.\n   */\n  public lockVoiceStateHandler() {\n    this.options.lockVoiceStateHandler = true;\n  }\n\n  /**\n   * Unlock voice state handler. When this method is called, discord-player will stop using the default voice state update handler if custom implementation exists.\n   */\n  public unlockVoiceStateHandler() {\n    this.options.lockVoiceStateHandler = false;\n  }\n\n  /**\n   * Checks if voice state handler is locked.\n   */\n  public isVoiceStateHandlerLocked() {\n    return !!this.options.lockVoiceStateHandler;\n  }\n\n  /**\n   * Initiate audio player\n   * @param channel The voice channel on which the music should be played\n   * @param query The track or source to play\n   * @param options Options for player\n   * @example ```typescript\n   * // no need to worry about queue management, just use this method \uD83D\uDE04\n   * const query = 'this is my super cool search query that I want to play';\n   *\n   * try {\n   *    const { track } = await player.play(voiceChannel, query);\n   *   console.log(`\uD83C\uDF89 I am playing ${track.title} \uD83C\uDF89`);\n   * } catch(e) {\n   *   console.log(`\uD83D\uDE2D Failed to play error oh no:\\n\\n${e}`);\n   * }\n   * ```\n   */\n  public async play<T = unknown>(\n  channel: GuildVoiceChannelResolvable,\n  query: TrackLike,\n  options: PlayerNodeInitializerOptions<T> = {})\n  : Promise<PlayerNodeInitializationResult<T>> {\n    const vc = this.client.channels.resolve(channel);\n    if (!vc?.isVoiceBased())\n    throw new InvalidArgTypeError('channel', 'VoiceBasedChannel', !vc ? 'undefined' : `channel type ${vc.type}`);\n\n    const originalResult = query instanceof SearchResult ? query : await this.search(query, options);\n    const result = (await options.afterSearch?.(originalResult)) || originalResult;\n    if (result.isEmpty()) {\n      throw new NoResultError(`No results found for \"${query}\" (Extractor: ${result.extractor?.identifier || 'N/A'})`);\n    }\n\n    const queue = this.nodes.create(vc.guild, options.nodeOptions);\n\n    if (this.hasDebugger) this.debug(`[AsyncQueue] Acquiring an entry...`);\n    const entry = queue.tasksQueue.acquire({ signal: options.signal });\n    if (this.hasDebugger) this.debug(`[AsyncQueue] Entry ${entry.id} was acquired successfully!`);\n\n    if (this.hasDebugger) this.debug(`[AsyncQueue] Waiting for the queue to resolve...`);\n    await entry.getTask();\n    if (this.hasDebugger) this.debug(`[AsyncQueue] Entry ${entry.id} was resolved!`);\n\n    try {\n      if (!queue.channel) await queue.connect(vc, options.connectionOptions);\n\n      if (!result.playlist) {\n        queue.addTrack(result.tracks[0]);\n      } else {\n        queue.addTrack(result.playlist);\n      }\n      if (!queue.isPlaying()) await queue.node.play(null, options.audioPlayerOptions);\n    } finally {\n      if (this.hasDebugger) this.debug(`[AsyncQueue] Releasing an entry from the queue...`);\n      queue.tasksQueue.release();\n    }\n\n    return {\n      track: result.tracks[0],\n      extractor: result.extractor,\n      searchResult: result,\n      queue\n    };\n  }\n\n  /**\n   * Search tracks\n   * @param {string | Track | Track[] | Playlist | SearchResult} query The search query\n   * @param {SearchOptions} options The search options\n   * @returns {Promise<SearchResult>}\n   * @example ```typescript\n   * const searchQuery = 'pass url or text or discord-player track constructable objects, we got you covered \uD83D\uDE0E';\n   * const result = await player.search(searchQuery);\n   *\n   * console.log(result); // Logs `SearchResult` object\n   * ```\n   */\n  public async search(searchQuery: TrackLike, options: SearchOptions = {}): Promise<SearchResult> {\n    if (searchQuery instanceof SearchResult) return searchQuery;\n\n    if (searchQuery instanceof AudioResource) {\n      searchQuery = this.createTrackFromAudioResource(searchQuery);\n    }\n\n    if (options.requestedBy != null) options.requestedBy = this.client.users.resolve(options.requestedBy)!;\n\n    options.blockExtractors ??= this.options.blockExtractors;\n    options.fallbackSearchEngine ??= QueryType.AUTO_SEARCH;\n\n    if (searchQuery instanceof Track) {\n      return new SearchResult(this, {\n        playlist: searchQuery.playlist || null,\n        tracks: [searchQuery],\n        query: searchQuery.title,\n        extractor: searchQuery.extractor,\n        queryType: searchQuery.queryType,\n        requestedBy: options.requestedBy\n      });\n    }\n\n    if (searchQuery instanceof Playlist) {\n      return new SearchResult(this, {\n        playlist: searchQuery,\n        tracks: searchQuery.tracks,\n        query: searchQuery.title,\n        extractor: searchQuery.tracks[0]?.extractor,\n        queryType: QueryType.AUTO,\n        requestedBy: options.requestedBy\n      });\n    }\n\n    if (Array.isArray(searchQuery)) {\n      const tracks = searchQuery.filter((t) => t instanceof Track);\n      return new SearchResult(this, {\n        playlist: null,\n        tracks,\n        query: '@@#%{{UserLoadedContent}}%#@@',\n        extractor: null,\n        queryType: QueryType.AUTO,\n        requestedBy: options.requestedBy\n      });\n    }\n\n    if (this.hasDebugger) this.debug(`Searching ${searchQuery}`);\n\n    let extractor: BaseExtractor | null = null,\n      protocol: string | null = null;\n\n    options.searchEngine ??= QueryType.AUTO;\n    options.fallbackSearchEngine ??= QueryType.AUTO_SEARCH;\n\n    if (this.hasDebugger)\n    this.debug(\n      `Search engine set to ${options.searchEngine}, fallback search engine set to ${options.fallbackSearchEngine}`\n    );\n\n    if (/^\\w+:/.test(searchQuery)) {\n      const [protocolName, ...query] = searchQuery.split(':');\n      if (this.hasDebugger) this.debug(`Protocol ${protocolName} detected in query`);\n\n      const matchingExtractor = this.extractors.store.find(\n        (e) => !this.extractors.isDisabled(e.identifier) && e.protocols.includes(protocolName)\n      );\n\n      if (matchingExtractor) {\n        if (this.hasDebugger)\n        this.debug(`Protocol ${protocolName} is supported by ${matchingExtractor.identifier} extractor!`);\n        extractor = matchingExtractor;\n        searchQuery = query.join(':');\n        protocol = protocolName;\n      } else {\n        if (this.hasDebugger)\n        this.debug(\n          `Could not find an extractor that supports ${protocolName} protocol. Falling back to default behavior...`\n        );\n      }\n    }\n\n    const redirected = await QueryResolver.preResolve(searchQuery);\n    const { type: queryType, query } =\n    options.searchEngine === QueryType.AUTO ?\n    QueryResolver.resolve(redirected, options.fallbackSearchEngine) :\n    { type: options.searchEngine, query: redirected } as ResolvedQuery;\n\n    if (this.hasDebugger)\n    this.debug(\n      `Query type identified as ${queryType}${\n      extractor && protocol ? ' but might not be used due to the presence of protocol' : ''}`\n\n    );\n\n    // force particular extractor\n    if (options.searchEngine.startsWith('ext:')) {\n      if (this.hasDebugger) this.debug(`Forcing ${options.searchEngine.substring(4)} extractor...`);\n      extractor = this.extractors.get(options.searchEngine.substring(4))!;\n      if (!extractor)\n      return new SearchResult(this, {\n        query,\n        queryType,\n        extractor,\n        requestedBy: options.requestedBy\n      });\n    }\n\n    // query all extractors\n    if (!extractor) {\n      // cache validation\n      if (!options.ignoreCache) {\n        if (this.hasDebugger) this.debug(`Checking cache...`);\n        const res = await this.queryCache?.resolve({\n          query,\n          queryType,\n          requestedBy: options.requestedBy\n        });\n        // cache hit\n        if (res?.hasTracks()) {\n          if (this.hasDebugger) this.debug(`Cache hit for query ${query}`);\n          return res;\n        }\n\n        if (this.hasDebugger) this.debug(`Cache miss for query ${query}`);\n      }\n\n      if (this.hasDebugger) this.debug(`Executing extractors...`);\n\n      // cache miss\n      extractor =\n      (\n      await this.extractors.run(async (ext) => {\n        if (options.blockExtractors?.includes(ext.identifier)) return false;\n        return ext.validate(query, queryType as SearchQueryType);\n      }))?.\n      extractor || null;\n    }\n\n    // no extractors available\n    if (!extractor) {\n      if (this.hasDebugger) this.debug('Failed to find appropriate extractor');\n      return new SearchResult(this, {\n        query,\n        queryType,\n        requestedBy: options.requestedBy\n      });\n    }\n\n    if (this.hasDebugger) this.debug(`Executing metadata query using ${extractor.identifier} extractor...`);\n    const res = await extractor.\n    handle(query, {\n      type: queryType as SearchQueryType,\n      requestedBy: options.requestedBy as User,\n      requestOptions: options.requestOptions,\n      protocol\n    }).\n    catch(() => null);\n\n    if (res) {\n      if (this.hasDebugger) this.debug('Metadata query was successful!');\n      const result = new SearchResult(this, {\n        query,\n        queryType,\n        playlist: res.playlist,\n        tracks: res.tracks,\n        extractor,\n        requestedBy: options.requestedBy\n      });\n\n      if (!options.ignoreCache) {\n        if (this.hasDebugger) this.debug(`Adding data to cache...`);\n        await this.queryCache?.addData(result);\n      }\n\n      return result;\n    }\n\n    if (this.hasDebugger) this.debug('Failed to find result using appropriate extractor. Querying all extractors...');\n    const result = await this.extractors.run(\n      async (ext) =>\n      !options.blockExtractors?.includes(ext.identifier) && (\n      await ext.validate(query)) &&\n      ext.handle(query, {\n        type: queryType as SearchQueryType,\n        requestedBy: options.requestedBy as User,\n        requestOptions: options.requestOptions,\n        protocol\n      })\n    );\n    if (!result?.result) {\n      if (this.hasDebugger)\n      this.debug(`Failed to query metadata query using ${result?.extractor.identifier || 'N/A'} extractor.`);\n      return new SearchResult(this, {\n        query,\n        queryType,\n        requestedBy: options.requestedBy,\n        extractor: result?.extractor\n      });\n    }\n\n    if (this.hasDebugger) this.debug(`Metadata query was successful using ${result.extractor.identifier}!`);\n\n    const data = new SearchResult(this, {\n      query,\n      queryType,\n      playlist: result.result.playlist,\n      tracks: result.result.tracks,\n      extractor: result.extractor,\n      requestedBy: options.requestedBy\n    });\n\n    if (!options.ignoreCache) {\n      if (this.hasDebugger) this.debug(`Adding data to cache...`);\n      await this.queryCache?.addData(data);\n    }\n\n    return data;\n  }\n\n  /**\n   * Generates a report of the dependencies used by the `discord-voip` module. Useful for debugging.\n   * @example ```typescript\n   * console.log(player.scanDeps());\n   * // -> logs dependencies report\n   * ```\n   * @returns {string}\n   */\n  public scanDeps() {\n    const line = '-'.repeat(50);\n    const runtime = 'Bun' in globalThis ? 'Bun' : 'Deno' in globalThis ? 'Deno' : 'Node';\n    const depsReport = [\n    'Discord Player',\n    line,\n    `- discord-player: ${Player.version}${\n    this.isCompatMode() ? ` (${getCompatName(this.client)} compatibility mode)` : ''}`,\n\n    `- discord-voip: ${dVoiceVersion}`,\n    `- discord.js: ${djsVersion}`,\n    `- Node version: ${process.version} (Detected Runtime: ${runtime}, Platform: ${process.platform} [${process.arch}])`,\n    (() => {\n      const info = FFmpeg.resolveSafe();\n      if (!info) return 'FFmpeg/Avconv not found';\n\n      return [\n      `- ffmpeg: ${info.version}`,\n      `- command: ${info.command}`,\n      `- static: ${info.module}`,\n      `- libopus: ${info.result!.includes('--enable-libopus')}`].\n      join('\\n');\n    })(),\n    '\\n',\n    'Loaded Extractors:',\n    line,\n    this.extractors.store.\n    map((m) => {\n      return m.identifier;\n    }).\n    join('\\n') || 'N/A',\n    '\\n\\ndiscord-voip',\n    DependencyReportGenerator.generateString()];\n\n\n    return depsReport.join('\\n');\n  }\n\n  public *[Symbol.iterator]() {\n    yield* this.nodes.cache.values();\n  }\n\n  /**\n   * Creates `Playlist` instance\n   * @param data The data to initialize a playlist\n   */\n  public createPlaylist(data: PlaylistInitData) {\n    return new Playlist(this, data);\n  }\n\n  /**\n   * Creates a track from an audio resource.\n   * @param resource The audio resource\n   */\n  public createTrackFromAudioResource(resource: AudioResource) {\n    const metadata = resource.metadata as Record<string, unknown>;\n    const ref = SnowflakeUtil.generate().toString();\n    const maybeTitle = 'title' in metadata ? `${metadata.title}` : `Track ${ref}`;\n    const maybeAuthor = 'author' in metadata ? `${metadata.author}` : 'Unknown author';\n    const maybeDuration = 'duration' in metadata ? `${metadata.duration}` : '00:00';\n    const maybeThumbnail = 'thumbnail' in metadata ? `${metadata.thumbnail}` : undefined;\n    const maybeURL = 'url' in metadata ? `${metadata.url}` : `discord-player://blob/${ref}`;\n    const maybeDescription = 'description' in metadata ? `${metadata.description}` : 'No description available.';\n    const maybeViews = 'views' in metadata ? Number(metadata.views) || 0 : 0;\n\n    const track = new Track(this, {\n      title: maybeTitle,\n      author: maybeAuthor,\n      duration: maybeDuration,\n      thumbnail: maybeThumbnail,\n      url: maybeURL,\n      description: maybeDescription,\n      queryType: QueryType.DISCORD_PLAYER_BLOB,\n      source: 'arbitrary',\n      metadata,\n      live: false,\n      views: maybeViews\n    });\n\n    resource.metadata = track;\n\n    track.setResource(resource as AudioResource<Track>);\n\n    return track;\n  }\n}", "import { ChannelType, VoiceState } from 'discord.js';\nimport { GuildQueue, GuildQueueEvent } from './queue';\nimport { Player } from './Player';\nimport { Util } from './utils/Util';\n\nfunction handleEmptyChannel(player: Player, queue: GuildQueue, guildId: string) {\n  const timeout = setTimeout(() => {\n    if (!Util.isVoiceEmpty(queue.channel!) || !player.nodes.has(queue.guild.id)) return;\n    if (queue.options.leaveOnEmpty) queue.delete();\n    player.events.emit(GuildQueueEvent.EmptyChannel, queue);\n  }, queue.options.leaveOnEmptyCooldown || 0).unref();\n  queue.timeouts.set(`empty_${guildId}`, timeout);\n}\n\nfunction handleChannelPopulate(player: Player, queue: GuildQueue, guildId: string) {\n  const emptyTimeout = queue.timeouts.get(`empty_${guildId}`);\n  if (!Util.isVoiceEmpty(queue.channel!) && emptyTimeout) {\n    clearTimeout(emptyTimeout);\n    queue.timeouts.delete(`empty_${guildId}`);\n    player.events.emit(GuildQueueEvent.ChannelPopulate, queue);\n  }\n}\n\nfunction handlePauseOnEmpty(queue: GuildQueue) {\n  const isEmpty = Util.isVoiceEmpty(queue.channel!);\n  const wasPausedOnEmpty = Reflect.get(queue, '__pausedOnEmpty');\n\n  if (isEmpty && !wasPausedOnEmpty) {\n    queue.node.setPaused(true);\n    Reflect.set(queue, '__pausedOnEmpty', true);\n    if (queue.hasDebugger) {\n      queue.debug('Voice channel is empty and options#pauseOnEmpty is true, pausing...');\n    }\n  } else if (!isEmpty && wasPausedOnEmpty) {\n    queue.node.setPaused(false);\n    Reflect.set(queue, '__pausedOnEmpty', false);\n    if (queue.hasDebugger) {\n      queue.debug('Voice channel is not empty and options#pauseOnEmpty is true, resuming...');\n    }\n  }\n}\n\nfunction handleBotVoiceStateUpdate(queue: GuildQueue, oldState: VoiceState, newState: VoiceState) {\n  if (newState.serverMute != null && oldState.serverMute !== newState.serverMute) {\n    queue.node.setPaused(newState.serverMute);\n    return;\n  }\n\n  if (\n  newState.channel?.type === ChannelType.GuildStageVoice &&\n  newState.suppress != null &&\n  oldState.suppress !== newState.suppress)\n  {\n    queue.node.setPaused(newState.suppress);\n    if (newState.suppress) {\n      newState.guild.members.me?.voice.setRequestToSpeak(true).catch(Util.noop);\n    }\n  }\n}\n\nexport async function defaultVoiceStateHandler(\nplayer: Player,\nqueue: GuildQueue,\noldState: VoiceState,\nnewState: VoiceState)\n{\n  if (!queue?.connection || !queue.channel) return;\n\n  const isBotState = newState.member?.id === newState.guild.members.me?.id;\n  const guildId = oldState.guild.id;\n\n  // Bot disconnected\n  if (isBotState && oldState.channelId && !newState.channelId) {\n    try {\n      queue.delete();\n    } catch {\n\n      /* noop */}\n    return void player.events.emit(GuildQueueEvent.Disconnect, queue);\n  }\n\n  if (queue.options.pauseOnEmpty) {\n    handlePauseOnEmpty(queue);\n  }\n\n  // Bot joined channel or changed state\n  if (isBotState && newState.channelId && (!oldState.channelId || oldState.channelId !== newState.channelId)) {\n    if (queue.connection) queue.channel = newState.channel!;\n    handleBotVoiceStateUpdate(queue, oldState, newState);\n  }\n\n  // Handle channel empty/populate events\n  if (!newState.channelId && oldState.channelId === queue.channel.id) {\n    if (!Util.isVoiceEmpty(queue.channel)) return;\n    handleEmptyChannel(player, queue, guildId);\n  } else if (newState.channelId === queue.channel.id) {\n    handleChannelPopulate(player, queue, guildId);\n  } else if (oldState.channelId !== newState.channelId) {\n    if (newState.channelId !== queue.channel.id && !Util.isVoiceEmpty(queue.channel)) return;\n    if (!queue.timeouts.has(`empty_${guildId}`)) {\n      handleEmptyChannel(player, queue, guildId);\n    }\n  }\n}", "import { resolve, dirname } from 'node:path';\nimport { FFmpeg, FFmpegLib } from '@discord-player/ffmpeg';\nimport { version } from '../version';\n\nexport interface PackageJSON {\n  name: string;\n  version: string;\n}\n\nexport type MaybeNull<T> = T | null;\n\nexport interface DependenciesReport {\n  core: {\n    'discord-player': string;\n    'discord-voip': string;\n  };\n  libopus: {\n    mediaplex: MaybeNull<string>;\n    '@discordjs/opus': MaybeNull<string>;\n    '@evan/opus': MaybeNull<string>;\n    opusscript: MaybeNull<string>;\n    'node-opus': MaybeNull<string>;\n  };\n  libsodium: {\n    'sodium-native': MaybeNull<string>;\n    sodium: MaybeNull<string>;\n    'libsodium-wrappers': MaybeNull<string>;\n    'sodium-javascript': MaybeNull<string>;\n    '@stablelib/xchacha20poly1305': MaybeNull<string>;\n    '@nobel/ciphers': MaybeNull<string>;\n  };\n  ffmpeg: FFmpegReport;\n}\n\nexport type FFmpegReport = Record<\n  FFmpegLib,\n  MaybeNull<{\n    version: string;\n    hasLibopus: boolean;\n  }>>;\n\n\n/**\n * A utility to generate a report of the dependencies used by the discord-player module.\n */\nexport const DependencyReportGenerator = {\n  /**\n   * Finds the package.json file of a package.\n   * @param dir - The directory to start searching from\n   * @param packageName - The name of the package to find\n   * @param depth - The maximum depth to search\n   * @returns The package.json file, or null if not found\n   */\n  findPackageJSON(dir: string, packageName: string, depth: number): PackageJSON | null {\n    if (depth === 0) return null;\n\n    const target = resolve(dir, 'package.json');\n\n    const next = () => DependencyReportGenerator.findPackageJSON(resolve(dir, '..'), packageName, depth - 1);\n\n    try {\n      // eslint-disable-next-line @typescript-eslint/no-var-requires\n      const pkgJSON: PackageJSON = require(target);\n\n      if (pkgJSON.name !== packageName) {\n        return next();\n      }\n\n      return pkgJSON;\n    } catch {\n      return next();\n    }\n  },\n  /**\n   * Tries to find the version of a dependency.\n   * @param name - The package to find the version of\n   * @param maxLookupDepth - The maximum depth to search for the package.json file\n   * @returns The version of the package, or null if not found\n   */\n  version(name: string, maxLookupDepth = 3): string | null {\n    try {\n      if (name === 'discord-player') {\n        return version;\n      }\n\n      const pkg = DependencyReportGenerator.findPackageJSON(dirname(require.resolve(name)), name, maxLookupDepth);\n      return pkg?.version ?? null;\n    } catch {\n      return null;\n    }\n  },\n  /**\n   * Generates a report of the dependencies used by the discord-player module.\n   * @returns The report object\n   */\n  generate(): DependenciesReport {\n    const ffmpegReport = {} as FFmpegReport;\n\n    for (const lib of FFmpeg.sources) {\n      ffmpegReport[lib.name] = null;\n    }\n\n    const ffmpeg = FFmpeg.resolveSafe();\n\n    if (ffmpeg) {\n      ffmpegReport[ffmpeg.name] = {\n        hasLibopus: ffmpeg.command.includes('--enable-libopus'),\n        version: ffmpeg.version\n      };\n    }\n\n    return {\n      core: {\n        'discord-player': DependencyReportGenerator.version('discord-player') as string,\n        'discord-voip': DependencyReportGenerator.version('discord-voip') as string\n      },\n      libopus: {\n        mediaplex: DependencyReportGenerator.version('mediaplex'),\n        '@discordjs/opus': DependencyReportGenerator.version('@discordjs/opus'),\n        '@evan/opus': DependencyReportGenerator.version('@evan/opus'),\n        opusscript: DependencyReportGenerator.version('opusscript'),\n        'node-opus': DependencyReportGenerator.version('node-opus')\n      },\n      libsodium: {\n        'sodium-native': DependencyReportGenerator.version('sodium-native'),\n        sodium: DependencyReportGenerator.version('sodium'),\n        'libsodium-wrappers': DependencyReportGenerator.version('libsodium-wrappers'),\n        '@stablelib/xchacha20poly1305': DependencyReportGenerator.version('@stablelib/xchacha20poly1305'),\n        'sodium-javascript': DependencyReportGenerator.version('sodium-javascript'),\n        '@nobel/ciphers': DependencyReportGenerator.version('@nobel/ciphers')\n      },\n      ffmpeg: ffmpegReport\n    };\n  },\n  /**\n   * Generates a string representation of the dependencies report.\n   * @returns The string representation\n   */\n  generateString(): string {\n    const report = DependencyReportGenerator.generate();\n    const line = '-'.repeat(50);\n\n    const output: string[] = [];\n\n    output.push('Dependencies Report');\n    output.push(line);\n\n    const keys = Object.keys(report) as (keyof DependenciesReport)[];\n\n    for (const _key of keys) {\n      const key = _key as keyof DependenciesReport;\n\n      output.push(key);\n\n      const subKeys = Object.keys(report[key]);\n\n      for (const _subKey of subKeys) {\n        const subKey = _subKey as keyof DependenciesReport[typeof key];\n        const value = report[key][subKey] ?? 'N/A';\n\n        output.push(`- ${subKey}: ${typeof value === 'object' ? JSON.stringify(value, null, 2) : value}`);\n      }\n\n      output.push('');\n    }\n\n    output.push(line);\n\n    return output.join('\\n');\n  }\n};", "\n\n\n\n\n\nexport const version = /* @__MACRO__ getVersion */\"7.0.0\";"],
  "mappings": "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",
  "names": ["GuildQueue", "SerializedType", "query", "version", "module", "import_utils", "import_utils", "result", "import_utils", "import_discord", "import_utils", "import_utils", "import_discord_voip", "import_utils", "import_discord_voip", "import_promises", "import_discord", "resolve", "resolve", "waitFor", "import_equalizer", "TrackSkipReason", "resolve", "GuildQueue", "GuildQueue", "import_promises", "version", "import_discord_voip", "import_utils", "import_ffmpeg", "import_discord", "import_discord_voip", "import_discord", "import_ffmpeg", "djsVersion", "query", "res", "result", "dVoiceVersion", "import_equalizer", "import_discord_voip"]
}

|