Flatlogic Bot ca3a32f23e V 4
2026-02-16 06:55:36 +00:00

166 lines
6.3 KiB
JavaScript

var __defProp = Object.defineProperty;
var __name = (target, value) => __defProp(target, "name", { value, configurable: true });
// src/index.ts
import { Soundcloud } from "soundcloud.ts";
import { DisTubeError, ExtractorPlugin, Playlist, Song, checkInvalidKey } from "distube";
var isTruthy = /* @__PURE__ */ __name((x) => Boolean(x), "isTruthy");
var SearchType = /* @__PURE__ */ ((SearchType2) => {
SearchType2["Track"] = "track";
SearchType2["Playlist"] = "playlist";
return SearchType2;
})(SearchType || {});
var SoundCloudPlugin = class extends ExtractorPlugin {
static {
__name(this, "SoundCloudPlugin");
}
soundcloud;
constructor(options = {}) {
super();
if (typeof options !== "object" || Array.isArray(options)) {
throw new DisTubeError("INVALID_TYPE", ["object", "undefined"], options, "SoundCloudPluginOptions");
}
checkInvalidKey(options, ["clientId", "oauthToken"], "SoundCloudPluginOptions");
if (options.clientId && typeof options.clientId !== "string") {
throw new DisTubeError("INVALID_TYPE", "string", options.clientId, "clientId");
}
if (options.oauthToken && typeof options.oauthToken !== "string") {
throw new DisTubeError("INVALID_TYPE", "string", options.oauthToken, "oauthToken");
}
this.soundcloud = new Soundcloud(options.clientId, options.oauthToken);
}
async search(query, type = "track" /* Track */, limit = 10, options = {}) {
if (typeof query !== "string") {
throw new DisTubeError("INVALID_TYPE", "string", query, "query");
}
if (!Object.values(SearchType).includes(type)) {
throw new DisTubeError("INVALID_TYPE", Object.values(SearchType), type, "type");
}
if (typeof limit !== "number" || limit < 1 || !Number.isInteger(limit)) {
throw new DisTubeError("INVALID_TYPE", "natural number", limit, "limit");
}
if (typeof options !== "object" || Array.isArray(options)) {
throw new DisTubeError("INVALID_TYPE", "object", options, "ResolveOptions");
}
await this.soundcloud.api.getClientId().catch(() => {
throw new DisTubeError(
"SOUNDCLOUD_PLUGIN_NO_CLIENT_ID",
"Cannot find SoundCloud client id automatically. Please provide a client id in the constructor.\nGuide: https://github.com/distubejs/soundcloud#documentation"
);
});
switch (type) {
case "track" /* Track */: {
const data = await this.soundcloud.tracks.search({ q: query, limit });
if (!data?.collection?.length) {
throw new DisTubeError("SOUNDCLOUD_PLUGIN_NO_RESULT", `Cannot find any "${query}" ${type} on SoundCloud!`);
}
return data.collection.map((t) => new SoundCloudSong(this, t, options));
}
case "playlist" /* Playlist */: {
const data = await this.soundcloud.playlists.search({ q: query, limit });
const playlists = data.collection;
return (await Promise.all(
playlists.map(async (p) => new SoundCloudPlaylist(this, await this.soundcloud.playlists.fetch(p), options))
)).filter(isTruthy);
}
default:
throw new DisTubeError("SOUNDCLOUD_PLUGIN_UNSUPPORTED_TYPE", `${type} search is not supported!`);
}
}
validate(url) {
return /^https?:\/\/(?:(?:www|m)\.)?soundcloud\.com\/(.*)$/.test(url);
}
async resolve(url, options) {
await this.soundcloud.api.getClientId().catch(() => {
throw new DisTubeError(
"SOUNDCLOUD_PLUGIN_NO_CLIENT_ID",
"Cannot find SoundCloud client id automatically. Please provide a client id in the constructor.\nGuide: https://github.com/distubejs/soundcloud#documentation"
);
});
const opt = { ...options, source: "soundcloud" };
url = url.replace(/:\/\/(m|www)\./g, "://");
const data = await this.soundcloud.resolve.get(url, true).catch((e) => {
throw new DisTubeError("SOUNDCLOUD_PLUGIN_RESOLVE_ERROR", e.message);
});
if (!data || !["track", "playlist"].includes(data.kind)) {
throw new DisTubeError("SOUNDCLOUD_PLUGIN_NOT_SUPPORTED", "Only public tracks and playlists are supported.");
}
return data.kind === "playlist" ? new SoundCloudPlaylist(this, await this.soundcloud.playlists.fetch(data), opt) : new SoundCloudSong(this, data, opt);
}
async getRelatedSongs(song) {
if (!song.url) {
throw new DisTubeError("SOUNDCLOUD_PLUGIN_INVALID_SONG", "Cannot get related songs from invalid song.");
}
const related = await this.soundcloud.tracks.related(song.url, 10);
return related.filter((t) => t.title).map((t) => new SoundCloudSong(this, t));
}
async getStreamURL(song) {
if (!song.url) {
throw new DisTubeError("SOUNDCLOUD_PLUGIN_INVALID_SONG", "Cannot get stream url from invalid song.");
}
const stream = await this.soundcloud.util.streamLink(song.url);
if (!stream) {
throw new DisTubeError(
"SOUNDCLOUD_PLUGIN_RATE_LIMITED",
"Reached SoundCloud rate limits\nSee more: https://developers.soundcloud.com/docs/api/rate-limits#play-requests"
);
}
return stream;
}
async searchSong(query, options) {
const songs = await this.search(query, "track" /* Track */, 1, options);
return songs[0];
}
};
var SoundCloudSong = class extends Song {
static {
__name(this, "SoundCloudSong");
}
constructor(plugin, info, options = {}) {
super(
{
plugin,
source: "soundcloud",
playFromSource: true,
id: info.id.toString(),
name: info.title,
url: info.permalink_url,
thumbnail: info.artwork_url,
duration: info.duration / 1e3,
views: info.playback_count,
uploader: {
name: info.user?.username,
url: info.user?.permalink_url
},
likes: info.likes_count,
reposts: info.reposts_count
},
options
);
}
};
var SoundCloudPlaylist = class extends Playlist {
static {
__name(this, "SoundCloudPlaylist");
}
constructor(plugin, info, options = {}) {
super(
{
source: "soundcloud",
id: info.id.toString(),
name: info.title,
url: info.permalink_url,
thumbnail: info.artwork_url ?? void 0,
songs: info.tracks.map((s) => new SoundCloudSong(plugin, s, options))
},
options
);
}
};
var src_default = SoundCloudPlugin;
export {
SearchType,
SoundCloudPlugin,
src_default as default
};
//# sourceMappingURL=index.mjs.map