diff --git a/src/VoiceInterface/VoiceUtils.ts b/src/VoiceInterface/VoiceUtils.ts index 3992152..3d3189e 100644 --- a/src/VoiceInterface/VoiceUtils.ts +++ b/src/VoiceInterface/VoiceUtils.ts @@ -42,7 +42,7 @@ class VoiceUtils { */ public static disconnect(connection: VoiceConnection | VoiceSubscription) { if (connection instanceof VoiceSubscription) return connection.voiceConnection.destroy(); - else connection.destroy(); + return connection.destroy(); } } diff --git a/src/index.ts b/src/index.ts index f4043fb..5061c5a 100644 --- a/src/index.ts +++ b/src/index.ts @@ -1,2 +1,4 @@ +export { AudioFilters } from "./utils/AudioFilters"; +export { PlayerError } from "./utils/PlayerError"; export { VoiceUtils } from "./VoiceInterface/VoiceUtils"; export { VoiceEvents, VoiceSubscription } from "./VoiceInterface/VoiceSubscription"; diff --git a/src/types/types.ts b/src/types/types.ts index cb0ff5c..fc657f8 100644 --- a/src/types/types.ts +++ b/src/types/types.ts @@ -1 +1,32 @@ -export {}; +export type FiltersName = keyof QueueFilters; + +export type QueueFilters = { + bassboost?: boolean; + "8D"?: boolean; + vaporwave?: boolean; + nightcore?: boolean; + phaser?: boolean; + tremolo?: boolean; + vibrato?: boolean; + reverse?: boolean; + treble?: boolean; + normalizer?: boolean; + surrounding?: boolean; + pulsator?: boolean; + subboost?: boolean; + karaoke?: boolean; + flanger?: boolean; + gate?: boolean; + haas?: boolean; + mcompand?: boolean; + mono?: boolean; + mstlr?: boolean; + mstrr?: boolean; + compressor?: boolean; + expander?: boolean; + softlimiter?: boolean; + chorus?: boolean; + chorus2d?: boolean; + chorus3d?: boolean; + fadein?: boolean; +}; diff --git a/src/utils/AudioFilters.ts b/src/utils/AudioFilters.ts index cb0ff5c..7ebf8e6 100644 --- a/src/utils/AudioFilters.ts +++ b/src/utils/AudioFilters.ts @@ -1 +1,108 @@ -export {}; +import { FiltersName } from "../types/types"; + +/** + * The available audio filters + * @typedef {Object} AudioFilters + * @property {String} bassboost The bassboost filter + * @property {String} 8D The 8D filter + * @property {String} vaporwave The vaporwave filter + * @property {String} nightcore The nightcore filter + * @property {String} phaser The phaser filter + * @property {String} tremolo The tremolo filter + * @property {String} vibrato The vibrato filter + * @property {String} reverse The reverse filter + * @property {String} treble The treble filter + * @property {String} normalizer The normalizer filter + * @property {String} surrounding The surrounding filter + * @property {String} pulsator The pulsator filter + * @property {String} subboost The subboost filter + * @property {String} kakaoke The kakaoke filter + * @property {String} flanger The flanger filter + * @property {String} gate The gate filter + * @property {String} haas The haas filter + * @property {String} mcompand The mcompand filter + * @property {String} mono The mono filter + * @property {String} mstlr The mstlr filter + * @property {String} mstrr The mstrr filter + * @property {String} compressor The compressor filter + * @property {String} expander The expander filter + * @property {String} softlimiter The softlimiter filter + * @property {String} chorus The chorus filter + * @property {String} chorus2d The chorus2d filter + * @property {String} chorus3d The chorus3d filter + * @property {String} fadein The fadein filter + */ + +const FilterList = { + bassboost: "bass=g=20", + "8D": "apulsator=hz=0.09", + vaporwave: "aresample=48000,asetrate=48000*0.8", + nightcore: "aresample=48000,asetrate=48000*1.25", + phaser: "aphaser=in_gain=0.4", + tremolo: "tremolo", + vibrato: "vibrato=f=6.5", + reverse: "areverse", + treble: "treble=g=5", + normalizer: "dynaudnorm=g=101", + surrounding: "surround", + pulsator: "apulsator=hz=1", + subboost: "asubboost", + karaoke: "stereotools=mlev=0.03", + flanger: "flanger", + gate: "agate", + haas: "haas", + mcompand: "mcompand", + mono: "pan=mono|c0=.5*c0+.5*c1", + mstlr: "stereotools=mode=ms>lr", + mstrr: "stereotools=mode=ms>rr", + compressor: "compand=points=-80/-105|-62/-80|-15.4/-15.4|0/-12|20/-7.6", + 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", + softlimiter: "compand=attacks=0:points=-80/-80|-12.4/-12.4|-6/-8|0/-6.8|20/-2.8", + chorus: "chorus=0.7:0.9:55:0.4:0.25:2", + chorus2d: "chorus=0.6:0.9:50|60:0.4|0.32:0.25|0.4:2|1.3", + 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", + fadein: "afade=t=in:ss=0:d=10", + + *[Symbol.iterator](): IterableIterator<{ name: FiltersName; value: string }> { + for (const [k, v] of Object.entries(this)) { + if (typeof this[k as FiltersName] === "string") yield { name: k as FiltersName, value: v as string }; + } + }, + + get names() { + return Object.keys(this).filter( + (p) => !["names", "length"].includes(p) && typeof this[p as FiltersName] !== "function" + ); + }, + + get length() { + return Object.keys(this).filter( + (p) => !["names", "length"].includes(p) && typeof this[p as FiltersName] !== "function" + ).length; + }, + + toString() { + return `${Object.values(this).join(",")}`; + }, + + create(filter?: FiltersName[]): string { + if (!filter || !Array.isArray(filter)) return this.toString(); + return filter + .filter((predicate) => typeof predicate === "string") + .map((m) => this[m]) + .join(","); + }, + + define(filterName: string, value: string): void { + if (typeof this[filterName as FiltersName] && typeof this[filterName as FiltersName] === "function") return; + + this[filterName as FiltersName] = value; + }, + + defineBulk(filterArray: { name: string; value: string }[]): void { + filterArray.forEach((arr) => this.define(arr.name, arr.value)); + } +}; + +export default FilterList; +export { FilterList as AudioFilters }; diff --git a/src/utils/PlayerError.ts b/src/utils/PlayerError.ts index cb0ff5c..af8110d 100644 --- a/src/utils/PlayerError.ts +++ b/src/utils/PlayerError.ts @@ -1 +1,10 @@ -export {}; +export default class PlayerError extends Error { + constructor(msg: string, name?: string) { + super(); + this.name = name ?? "PlayerError"; + this.message = msg; + Error.captureStackTrace(this); + } +} + +export { PlayerError };