ziplayer 0.1.3 → 0.1.4
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 +212 -212
- package/dist/plugins/SoundCloudPlugin.d.ts +22 -0
- package/dist/plugins/SoundCloudPlugin.d.ts.map +1 -0
- package/dist/plugins/SoundCloudPlugin.js +171 -0
- package/dist/plugins/SoundCloudPlugin.js.map +1 -0
- package/dist/plugins/SpotifyPlugin.d.ts +26 -0
- package/dist/plugins/SpotifyPlugin.d.ts.map +1 -0
- package/dist/plugins/SpotifyPlugin.js +183 -0
- package/dist/plugins/SpotifyPlugin.js.map +1 -0
- package/dist/plugins/YouTubePlugin.d.ts +25 -0
- package/dist/plugins/YouTubePlugin.d.ts.map +1 -0
- package/dist/plugins/YouTubePlugin.js +314 -0
- package/dist/plugins/YouTubePlugin.js.map +1 -0
- package/dist/structures/Player.d.ts +23 -13
- package/dist/structures/Player.d.ts.map +1 -1
- package/dist/structures/Player.js +129 -54
- package/dist/structures/Player.js.map +1 -1
- package/package.json +45 -45
- package/src/extensions/BaseExtension.ts +35 -35
- package/src/extensions/index.ts +32 -32
- package/src/index.ts +16 -16
- package/src/plugins/BasePlugin.ts +26 -26
- package/src/plugins/index.ts +32 -32
- package/src/structures/Player.ts +1828 -1747
- package/src/structures/PlayerManager.ts +411 -411
- package/src/structures/Queue.ts +354 -354
- package/src/types/index.ts +470 -470
- package/src/utils/timeout.ts +10 -10
- package/tsconfig.json +23 -23
package/src/extensions/index.ts
CHANGED
|
@@ -1,32 +1,32 @@
|
|
|
1
|
-
import { BaseExtension } from "./BaseExtension";
|
|
2
|
-
|
|
3
|
-
export { BaseExtension } from "./BaseExtension";
|
|
4
|
-
|
|
5
|
-
// Extension factory
|
|
6
|
-
export class ExtensionManager {
|
|
7
|
-
private extensions: Map<string, BaseExtension> = new Map();
|
|
8
|
-
|
|
9
|
-
register(extension: BaseExtension): void {
|
|
10
|
-
this.extensions.set(extension.name, extension);
|
|
11
|
-
}
|
|
12
|
-
|
|
13
|
-
unregister(name: string): boolean {
|
|
14
|
-
return this.extensions.delete(name);
|
|
15
|
-
}
|
|
16
|
-
|
|
17
|
-
get(name: string): BaseExtension | undefined {
|
|
18
|
-
return this.extensions.get(name);
|
|
19
|
-
}
|
|
20
|
-
|
|
21
|
-
getAll(): BaseExtension[] {
|
|
22
|
-
return Array.from(this.extensions.values());
|
|
23
|
-
}
|
|
24
|
-
|
|
25
|
-
findExtension(alas: any): BaseExtension | undefined {
|
|
26
|
-
return this.getAll().find((extension) => extension.active(alas));
|
|
27
|
-
}
|
|
28
|
-
|
|
29
|
-
clear(): void {
|
|
30
|
-
this.extensions.clear();
|
|
31
|
-
}
|
|
32
|
-
}
|
|
1
|
+
import { BaseExtension } from "./BaseExtension";
|
|
2
|
+
|
|
3
|
+
export { BaseExtension } from "./BaseExtension";
|
|
4
|
+
|
|
5
|
+
// Extension factory
|
|
6
|
+
export class ExtensionManager {
|
|
7
|
+
private extensions: Map<string, BaseExtension> = new Map();
|
|
8
|
+
|
|
9
|
+
register(extension: BaseExtension): void {
|
|
10
|
+
this.extensions.set(extension.name, extension);
|
|
11
|
+
}
|
|
12
|
+
|
|
13
|
+
unregister(name: string): boolean {
|
|
14
|
+
return this.extensions.delete(name);
|
|
15
|
+
}
|
|
16
|
+
|
|
17
|
+
get(name: string): BaseExtension | undefined {
|
|
18
|
+
return this.extensions.get(name);
|
|
19
|
+
}
|
|
20
|
+
|
|
21
|
+
getAll(): BaseExtension[] {
|
|
22
|
+
return Array.from(this.extensions.values());
|
|
23
|
+
}
|
|
24
|
+
|
|
25
|
+
findExtension(alas: any): BaseExtension | undefined {
|
|
26
|
+
return this.getAll().find((extension) => extension.active(alas));
|
|
27
|
+
}
|
|
28
|
+
|
|
29
|
+
clear(): void {
|
|
30
|
+
this.extensions.clear();
|
|
31
|
+
}
|
|
32
|
+
}
|
package/src/index.ts
CHANGED
|
@@ -1,16 +1,16 @@
|
|
|
1
|
-
import { PlayerManager, getGlobalManager } from "./structures/PlayerManager";
|
|
2
|
-
import type { PlayerManagerOptions } from "./types";
|
|
3
|
-
|
|
4
|
-
export { Player } from "./structures/Player";
|
|
5
|
-
export { Queue } from "./structures/Queue";
|
|
6
|
-
export { PlayerManager } from "./structures/PlayerManager";
|
|
7
|
-
export * from "./types";
|
|
8
|
-
export * from "./plugins";
|
|
9
|
-
export * from "./extensions";
|
|
10
|
-
|
|
11
|
-
// Default export
|
|
12
|
-
export default PlayerManager;
|
|
13
|
-
|
|
14
|
-
// Simple shared-instance accessor
|
|
15
|
-
export const getManager = () => getGlobalManager();
|
|
16
|
-
export const getPlayer = (guildOrId: string) => getManager()?.get(guildOrId);
|
|
1
|
+
import { PlayerManager, getGlobalManager } from "./structures/PlayerManager";
|
|
2
|
+
import type { PlayerManagerOptions } from "./types";
|
|
3
|
+
|
|
4
|
+
export { Player } from "./structures/Player";
|
|
5
|
+
export { Queue } from "./structures/Queue";
|
|
6
|
+
export { PlayerManager } from "./structures/PlayerManager";
|
|
7
|
+
export * from "./types";
|
|
8
|
+
export * from "./plugins";
|
|
9
|
+
export * from "./extensions";
|
|
10
|
+
|
|
11
|
+
// Default export
|
|
12
|
+
export default PlayerManager;
|
|
13
|
+
|
|
14
|
+
// Simple shared-instance accessor
|
|
15
|
+
export const getManager = () => getGlobalManager();
|
|
16
|
+
export const getPlayer = (guildOrId: string) => getManager()?.get(guildOrId);
|
|
@@ -1,26 +1,26 @@
|
|
|
1
|
-
import { SourcePlugin, Track, SearchResult, StreamInfo } from "../types";
|
|
2
|
-
|
|
3
|
-
export abstract class BasePlugin implements SourcePlugin {
|
|
4
|
-
abstract name: string;
|
|
5
|
-
abstract version: string;
|
|
6
|
-
|
|
7
|
-
abstract canHandle(query: string): boolean;
|
|
8
|
-
abstract search(query: string, requestedBy: string): Promise<SearchResult>;
|
|
9
|
-
abstract getStream(track: Track): Promise<StreamInfo>;
|
|
10
|
-
|
|
11
|
-
getFallback?(track: Track): Promise<StreamInfo> {
|
|
12
|
-
throw new Error("getFallback not implemented");
|
|
13
|
-
}
|
|
14
|
-
|
|
15
|
-
getRelatedTracks?(trackURL: string, opts?: { limit?: number; offset?: number; history?: Track[] }): Promise<Track[]> {
|
|
16
|
-
return Promise.resolve([]);
|
|
17
|
-
}
|
|
18
|
-
|
|
19
|
-
validate?(url: string): boolean {
|
|
20
|
-
return this.canHandle(url);
|
|
21
|
-
}
|
|
22
|
-
|
|
23
|
-
extractPlaylist?(url: string, requestedBy: string): Promise<Track[]> {
|
|
24
|
-
return Promise.resolve([]);
|
|
25
|
-
}
|
|
26
|
-
}
|
|
1
|
+
import { SourcePlugin, Track, SearchResult, StreamInfo } from "../types";
|
|
2
|
+
|
|
3
|
+
export abstract class BasePlugin implements SourcePlugin {
|
|
4
|
+
abstract name: string;
|
|
5
|
+
abstract version: string;
|
|
6
|
+
|
|
7
|
+
abstract canHandle(query: string): boolean;
|
|
8
|
+
abstract search(query: string, requestedBy: string): Promise<SearchResult>;
|
|
9
|
+
abstract getStream(track: Track): Promise<StreamInfo>;
|
|
10
|
+
|
|
11
|
+
getFallback?(track: Track): Promise<StreamInfo> {
|
|
12
|
+
throw new Error("getFallback not implemented");
|
|
13
|
+
}
|
|
14
|
+
|
|
15
|
+
getRelatedTracks?(trackURL: string, opts?: { limit?: number; offset?: number; history?: Track[] }): Promise<Track[]> {
|
|
16
|
+
return Promise.resolve([]);
|
|
17
|
+
}
|
|
18
|
+
|
|
19
|
+
validate?(url: string): boolean {
|
|
20
|
+
return this.canHandle(url);
|
|
21
|
+
}
|
|
22
|
+
|
|
23
|
+
extractPlaylist?(url: string, requestedBy: string): Promise<Track[]> {
|
|
24
|
+
return Promise.resolve([]);
|
|
25
|
+
}
|
|
26
|
+
}
|
package/src/plugins/index.ts
CHANGED
|
@@ -1,32 +1,32 @@
|
|
|
1
|
-
import { BasePlugin } from "./BasePlugin";
|
|
2
|
-
|
|
3
|
-
export { BasePlugin } from "./BasePlugin";
|
|
4
|
-
|
|
5
|
-
// Plugin factory
|
|
6
|
-
export class PluginManager {
|
|
7
|
-
private plugins: Map<string, BasePlugin> = new Map();
|
|
8
|
-
|
|
9
|
-
register(plugin: BasePlugin): void {
|
|
10
|
-
this.plugins.set(plugin.name, plugin);
|
|
11
|
-
}
|
|
12
|
-
|
|
13
|
-
unregister(name: string): boolean {
|
|
14
|
-
return this.plugins.delete(name);
|
|
15
|
-
}
|
|
16
|
-
|
|
17
|
-
get(name: string): BasePlugin | undefined {
|
|
18
|
-
return this.plugins.get(name);
|
|
19
|
-
}
|
|
20
|
-
|
|
21
|
-
getAll(): BasePlugin[] {
|
|
22
|
-
return Array.from(this.plugins.values());
|
|
23
|
-
}
|
|
24
|
-
|
|
25
|
-
findPlugin(query: string): BasePlugin | undefined {
|
|
26
|
-
return this.getAll().find((plugin) => plugin.canHandle(query));
|
|
27
|
-
}
|
|
28
|
-
|
|
29
|
-
clear(): void {
|
|
30
|
-
this.plugins.clear();
|
|
31
|
-
}
|
|
32
|
-
}
|
|
1
|
+
import { BasePlugin } from "./BasePlugin";
|
|
2
|
+
|
|
3
|
+
export { BasePlugin } from "./BasePlugin";
|
|
4
|
+
|
|
5
|
+
// Plugin factory
|
|
6
|
+
export class PluginManager {
|
|
7
|
+
private plugins: Map<string, BasePlugin> = new Map();
|
|
8
|
+
|
|
9
|
+
register(plugin: BasePlugin): void {
|
|
10
|
+
this.plugins.set(plugin.name, plugin);
|
|
11
|
+
}
|
|
12
|
+
|
|
13
|
+
unregister(name: string): boolean {
|
|
14
|
+
return this.plugins.delete(name);
|
|
15
|
+
}
|
|
16
|
+
|
|
17
|
+
get(name: string): BasePlugin | undefined {
|
|
18
|
+
return this.plugins.get(name);
|
|
19
|
+
}
|
|
20
|
+
|
|
21
|
+
getAll(): BasePlugin[] {
|
|
22
|
+
return Array.from(this.plugins.values());
|
|
23
|
+
}
|
|
24
|
+
|
|
25
|
+
findPlugin(query: string): BasePlugin | undefined {
|
|
26
|
+
return this.getAll().find((plugin) => plugin.canHandle(query));
|
|
27
|
+
}
|
|
28
|
+
|
|
29
|
+
clear(): void {
|
|
30
|
+
this.plugins.clear();
|
|
31
|
+
}
|
|
32
|
+
}
|