From 17793af2f1dfd56f596d348fb5677f655baf8892 Mon Sep 17 00:00:00 2001 From: Donald Shan Date: Sat, 10 Dec 2022 17:04:38 -0800 Subject: Initial Commit --- audio/Music.java | 507 ------------------------------------------------------- 1 file changed, 507 deletions(-) delete mode 100644 audio/Music.java (limited to 'audio/Music.java') diff --git a/audio/Music.java b/audio/Music.java deleted file mode 100644 index 45f0d3d..0000000 --- a/audio/Music.java +++ /dev/null @@ -1,507 +0,0 @@ -package audio; -import com.sedmelluq.discord.lavaplayer.player.AudioLoadResultHandler; -import com.sedmelluq.discord.lavaplayer.player.AudioPlayer; -import com.sedmelluq.discord.lavaplayer.player.AudioPlayerManager; -import com.sedmelluq.discord.lavaplayer.player.DefaultAudioPlayerManager; -import com.sedmelluq.discord.lavaplayer.source.AudioSourceManagers; -import com.sedmelluq.discord.lavaplayer.tools.FriendlyException; -import com.sedmelluq.discord.lavaplayer.track.AudioPlaylist; -import com.sedmelluq.discord.lavaplayer.track.AudioTrack; -import net.dv8tion.jda.api.EmbedBuilder; -import net.dv8tion.jda.api.MessageBuilder; -import net.dv8tion.jda.api.entities.*; -import net.dv8tion.jda.api.events.interaction.SelectionMenuEvent; -import net.dv8tion.jda.api.events.interaction.SlashCommandEvent; -import net.dv8tion.jda.api.events.message.guild.GuildMessageReceivedEvent; -import net.dv8tion.jda.api.hooks.ListenerAdapter; -import net.dv8tion.jda.api.interactions.components.selections.SelectOption; -import net.dv8tion.jda.api.interactions.components.selections.SelectionMenu; -import net.dv8tion.jda.api.managers.AudioManager; -import org.jetbrains.annotations.NotNull; -import org.json.JSONArray; -import org.json.JSONObject; -import org.jsoup.Jsoup; -import se.michaelthelin.spotify.model_objects.specification.PlaylistTrack; -import utility.SpotifyAPI; -import utility.URLChecker; - -import java.awt.*; -import java.io.*; -import java.net.MalformedURLException; -import java.net.URL; -import java.util.*; -import java.util.List; -import java.util.concurrent.BlockingQueue; -import java.util.concurrent.LinkedBlockingQueue; - - -public class Music extends ListenerAdapter { - ArrayList hololiveMusicURL = new ArrayList(); - String ytapiKey = ""; - String spotifyapiKey = ""; - static String append = "!"; - private URLChecker urlCheck = new URLChecker(); - private final AudioPlayerManager playerManager; - private final Map musicManagers; - private SpotifyAPI spotifyAPI = new SpotifyAPI(); - public Music(String append, String ytapiKey) { - this.musicManagers = new HashMap<>(); - this.ytapiKey = ytapiKey; - this.spotifyapiKey = spotifyapiKey; - this.append = append; - this.playerManager = new DefaultAudioPlayerManager(); - AudioSourceManagers.registerRemoteSources(playerManager); - AudioSourceManagers.registerLocalSource(playerManager); - System.out.println("Filling Music List"); - } - private synchronized GuildMusicManager getGuildAudioPlayer(Guild guild) { - long guildId = Long.parseLong(guild.getId()); - GuildMusicManager musicManager = musicManagers.get(guildId); - - if (musicManager == null) { - musicManager = new GuildMusicManager(playerManager); - musicManagers.put(guildId, musicManager); - } - guild.getAudioManager().setSendingHandler(musicManager.getSendHandler()); - - return musicManager; - } - private void populateVTuberMusic(){ - try { - URL url = new URL("https://pinapelz.github.io/vTuberDiscordBot/hololiveMusic.txt"); - BufferedReader in = new BufferedReader(new InputStreamReader(url.openStream())); - String line; - FileWriter writer = new FileWriter("data//hololiveMusic.txt"); - while ((line = in.readLine()) != null) { - writer.write(line+"\n"); - } - writer.close(); - in.close(); - } - catch (MalformedURLException e) { - System.out.println("Malformed URL: " + e.getMessage()); - } - catch (IOException e) { - System.out.println("I/O Error: " + e.getMessage()); - } - } - private void fillVTuberMusic(){ - populateVTuberMusic(); - Scanner s = null; - try { - s = new Scanner(new File("data//hololiveMusic.txt")); - } catch (FileNotFoundException e) { - e.printStackTrace(); - } - while (s.hasNext()){ - hololiveMusicURL.add(s.nextLine()); - } - s.close(); - } - @Override - public void onGuildMessageReceived(GuildMessageReceivedEvent event) { - Guild guild = event.getGuild(); - GuildMusicManager mng = getGuildAudioPlayer(guild); - TrackScheduler scheduler = mng.scheduler; - String[] command = event.getMessage().getContentRaw().split(" ", 2); - - if ((append+"play").equals(command[0]) && command.length == 2) { - loadAndPlay(event.getChannel(), command[1],true); - } - else if((append+"refreshlist").equals(command[0])){ - event.getChannel().sendMessage("Refreshing songs database").queue(); - fillVTuberMusic(); - event.getChannel().sendMessage("Refresh Complete!").queue(); - } - else if ((append+"shuffle").equals(command[0])) - { - if (scheduler.queue.isEmpty()) - { - event.getChannel().sendMessage("The queue is currently empty!").queue(); - return; - } - - scheduler.shuffle(); - event.getChannel().sendMessage("The queue has been shuffled!").queue(); - } - - else if("!holoadd".equals(command[0])){ - event.getChannel().sendMessage("The url has been successfully added to the database").queue(); - } - else if("!dev".equals(command[0])){ - try { - spotifyAPI.clientCredentials_Sync(); - } - catch (Exception e){ - - } - } - - super.onGuildMessageReceived(event); - } - public void playMusic(SlashCommandEvent event){ - try { - String userQuery = event.getOption("term").getAsString(); - if (urlCheck.isURL(userQuery) && !urlCheck.getURLType(userQuery).equals("spotify")&&!urlCheck.getURLType(userQuery).equals("spotify-playlist")) { //The term is a URL - event.reply("Found Video: " + userQuery).queue(); - loadAndPlay((TextChannel) event.getChannel(), userQuery, false); - } else { - try { - if (urlCheck.getURLType(userQuery).equals("spotify")){ - - event.deferReply().queue(); - event.getHook().sendMessage("Matched Video From Spotify: " + returnTopVideoURL(spotifyAPI.getSearchTerm_sync(urlCheck.getSpotifyTrackID(userQuery)))).queue(); - loadAndPlay((TextChannel) event.getChannel(), returnTopVideoURL(spotifyAPI.getSearchTerm_sync(urlCheck.getSpotifyTrackID(userQuery))), true); - } - else if(urlCheck.getURLType(userQuery).equals("spotify-playlist")){ - event.deferReply().queue(); - String randomSong = spotifyAPI.getRandomPlaylistTrack_Sync(urlCheck.getSpotifyPlaylistID(userQuery)); - event.getHook().sendMessage("Matched Video From Spotify Playlist: " + returnTopVideoURL(spotifyAPI.getSearchTerm_sync(randomSong))).queue(); - loadAndPlay((TextChannel) event.getChannel(), returnTopVideoURL(spotifyAPI.getSearchTerm_sync(randomSong)), true); - } - else { - event.reply("Found Video: " + returnTopVideoURL(userQuery)).queue(); - loadAndPlay((TextChannel) event.getChannel(), returnTopVideoURL(userQuery), true); - } - } catch (IOException e) { - e.printStackTrace(); - } - } - - } - catch(Exception e){ - event.reply("Error! Hazukashii! " + e.toString()); - } - } - - - public void setVolume( SlashCommandEvent event, String command){ - Guild guild = event.getGuild(); - GuildMusicManager mng = getGuildAudioPlayer(guild); - AudioPlayer player = mng.player; - if (command.equals("CHECK")) - { - event.reply("Current player volume: **" + player.getVolume() + "**").queue(); - } - else - { - try - { - int newVolume = Math.max(10, Math.min(100, Integer.parseInt(command))); - int oldVolume = player.getVolume(); - player.setVolume(newVolume); - event.reply("Player volume changed from `" + oldVolume + "` to `" + newVolume + "`").queue(); - } - catch (NumberFormatException e) - { - event.reply("`" + command + "` is not a valid integer. (10 - 100)").queue(); - } - } - } - public void stopPlayer(SlashCommandEvent event){ - Guild guild = event.getGuild(); - GuildMusicManager mng = getGuildAudioPlayer(guild); - AudioPlayer player = mng.player; - TrackScheduler scheduler = mng.scheduler; - scheduler.queue.clear(); - player.stopTrack(); - player.setPaused(false); - event.reply("Playback has been completely stopped and the queue has been cleared.").queue(); - } - public void pausePlayer(final TextChannel channel, SlashCommandEvent event){ - Guild guild = event.getGuild(); - GuildMusicManager mng = getGuildAudioPlayer(guild); - AudioPlayer player = mng.player; - if (player.getPlayingTrack() == null) - { - event.reply("Cannot pause or resume player because no track is loaded for playing.").queue(); - return; - } - player.setPaused(!player.isPaused()); - if (player.isPaused()) - event.reply("The player has been paused.").queue(); - else - event.reply("The player has resumed playing.").queue(); - } - public void queueVTMusic(final TextChannel channel, int songsToQueue){ - fillVTuberMusic(); - Collections.shuffle(hololiveMusicURL); - System.out.println("Requesting to queue " + songsToQueue + " songs"); - System.out.println("Queueing all Hololive Music"); - for (int i = 0;i queue = getGuildAudioPlayer(event.getGuild()).scheduler.queue; - synchronized (queue) - { - if (queue.isEmpty()) - { - event.reply("The queue is currently empty!").queue(); - } - else - { - int trackCount = 0; - long queueLength = 0; - StringBuilder sb = new StringBuilder(); - sb.append("```Current Queue: Entries: ").append(queue.size()).append("\n"); - for (AudioTrack track : queue) - { - queueLength += track.getDuration(); - if (trackCount < 10) - { - sb.append(trackCount+1 +". [").append(getTimestamp(track.getDuration())).append("] "); - sb.append(track.getInfo().title).append("\n"); - trackCount++; - } - } - sb.append("\n").append("Total Queue Time Length: ").append(getTimestamp(queueLength)+"```"); - event.reply(sb.toString()).queue(); - - } - } - } - public void showQueueMenu(final TextChannel channel, @NotNull SlashCommandEvent event, String param, String instruction){ - Queue queue = getGuildAudioPlayer(event.getGuild()).scheduler.queue; - List trackMenuOptions = new ArrayList(); - synchronized (queue) - { - if (queue.isEmpty()) - { - channel.sendMessage("The queue is currently empty!").queue(); - } - else - { - int trackCount = 0; - for (AudioTrack track : queue) - { - if (trackCount != 25) - { - SelectOption option = SelectOption.of(track.getInfo().title,param+" "+track.getInfo().title); - trackMenuOptions.add(option); - trackCount++; - } - } - SelectionMenu menu = SelectionMenu.create("menu:class") - .setPlaceholder("-Select a track-") // shows the placeholder indicating what this menu is for - .setRequiredRange(1,1)// only one can be selected - .addOptions(trackMenuOptions) - .build(); - event.reply(instruction) - .setEphemeral(true) - .addActionRow(menu) - .queue(); - - } - } - } - @Override - public void onSelectionMenu(SelectionMenuEvent event){ - if(event.getValues().get(0).contains("remove-queue")) { - boolean deletedSong = false; - Queue queue = getGuildAudioPlayer(event.getGuild()).scheduler.queue; - BlockingQueue newQueue = new LinkedBlockingQueue<>(); - String trackName = event.getValues().get(0).replaceAll("remove-queue ", ""); - synchronized (queue) { - if (queue.isEmpty()) - { - event.reply("The queue is currently empty!").queue(); - } - else { - for (AudioTrack track : queue) { - if (!track.getInfo().title.equals(trackName)) { - newQueue.add(track); - } - else{ - deletedSong = true; - } - } - getGuildAudioPlayer(event.getGuild()).scheduler.queue = newQueue; - if(deletedSong){ - event.reply("Removed " + trackName + " from the queue!").queue(); - } - else{ - event.reply("Could not find " + trackName + " in the queue!").queue(); - } - - } - - } - } - - else if(event.getValues().get(0).contains("inspect-queue")) { //THIS FEAUTURE IS NOT FINISHED - Queue queue = getGuildAudioPlayer(event.getGuild()).scheduler.queue; - BlockingQueue newQueue = new LinkedBlockingQueue<>(); - String trackName = event.getValues().get(0).replaceAll("inspect-queue ", ""); - synchronized (queue) { - if (queue.isEmpty()) - { - event.reply("The queue is currently empty!").queue(); - } - else { - for (AudioTrack track : queue) { - if (!track.getInfo().title.equals(trackName)) { - newQueue.add(track); - } - else{ - - } - } - getGuildAudioPlayer(event.getGuild()).scheduler.queue = newQueue; - } - - } - } - } - public void loadAndPlay(final @NotNull TextChannel channel, final String trackUrl, boolean returnMessage) { - GuildMusicManager musicManager = getGuildAudioPlayer(channel.getGuild()); - playerManager.loadItemOrdered(musicManager, trackUrl, new AudioLoadResultHandler() { - @Override - public void trackLoaded(AudioTrack track) { - if(returnMessage) { - channel.sendMessage("Adding to queue " + track.getInfo().title).queue(); - - } - - play(channel.getGuild(), musicManager, track); - } - - @Override - public void playlistLoaded(AudioPlaylist playlist) { - AudioTrack firstTrack = playlist.getSelectedTrack(); - - if (firstTrack == null) { - firstTrack = playlist.getTracks().get(0); - } -; if(returnMessage){ - channel.sendMessage("Adding to queue " + firstTrack.getInfo().title + " (first track of playlist " + playlist.getName() + ")").queue(); - } - - - play(channel.getGuild(), musicManager, firstTrack); - } - - @Override - public void noMatches() { - channel.sendMessage("Nothing found by " + trackUrl).queue(); - } - - @Override - public void loadFailed(FriendlyException exception) { - if(returnMessage) { - channel.sendMessage("Could not play: " + exception.getMessage()).queue(); - System.out.println(exception); - } - } - }); - - } - - - - private void play(Guild guild, GuildMusicManager musicManager, AudioTrack track) { - connectToFirstVoiceChannel(guild.getAudioManager()); - musicManager.scheduler.queue(track); - BlockingQueue s = musicManager.scheduler.queue; - - } - - public void skipTrack(TextChannel channel,SlashCommandEvent event) { - GuildMusicManager musicManager = getGuildAudioPlayer(channel.getGuild()); - musicManager.scheduler.nextTrack(); - - event.reply("Skipped to next track.").queue(); - } - - private static void connectToFirstVoiceChannel(AudioManager audioManager) { - if (!audioManager.isConnected() && !audioManager.isAttemptingToConnect()) { - for (VoiceChannel voiceChannel : audioManager.getGuild().getVoiceChannels()) { - audioManager.openAudioConnection(voiceChannel); - break; - } - } - } - private static String getTimestamp(long milliseconds) - { - int seconds = (int) (milliseconds / 1000) % 60 ; - int minutes = (int) ((milliseconds / (1000 * 60)) % 60); - int hours = (int) ((milliseconds / (1000 * 60 * 60)) % 24); - - if (hours > 0) - return String.format("%02d:%02d:%02d", hours, minutes, seconds); - else - return String.format("%02d:%02d", minutes, seconds); - } - - public String returnTopVideoURL(String keyword) throws IOException { - String url = "https://www.googleapis.com/youtube/v3/search?part=snippet&maxResults=1&q="+keyword+"&type=video&key="+ytapiKey; - url = url.replaceAll(" ", "%20"); - String data = Jsoup.connect(url).ignoreContentType(true).execute().body(); - JSONObject obj = new JSONObject(data); - JSONArray arr = obj.getJSONArray("items"); - String videoID = ""; - for (int i = 0; i < arr.length(); i++) - { - videoID = arr.getJSONObject(i).getJSONObject("id").getString("videoId"); - System.out.println("Parsed ID "+ videoID); - } - return "https://www.youtube.com/watch?v="+videoID; - } - - - - - -} -- cgit v1.2.3