mirror of
				https://github.com/JonasunderscoreJones/ZtereoMUSIC.git
				synced 2025-10-26 04:49:18 +01:00 
			
		
		
		
	fix: clean up README and files, add comments, and add last part of previous commit that was missing
This commit is contained in:
		
							parent
							
								
									b0c00d48ee
								
							
						
					
					
						commit
						bdbf2b44d5
					
				
					 4 changed files with 15 additions and 15 deletions
				
			
		|  | @ -41,13 +41,6 @@ | ||||||
| - [ ] Proper database for server preferences (prefix etc) | - [ ] Proper database for server preferences (prefix etc) | ||||||
| - Other TBA... | - Other TBA... | ||||||
| 
 | 
 | ||||||
| ## Noticed problems: |  | ||||||
| - The bot will always use the same channel (infochannel) after the first command which makes it behave strangely if you switch text chat after the first channel. |  | ||||||
| - Uh oh a track did something strange appears sometimes... (last time was when asking for a track in another channel) |  | ||||||
| - The bot randomly disconnects from the vc |  | ||||||
| - Queue index starts from 0 |  | ||||||
| - Sometimes the bot stops showing the green outline (maybe client bug, very rare) |  | ||||||
| 
 |  | ||||||
| ## Thankies | ## Thankies | ||||||
| This wouldn't have been possible without the amazing folks behind [lavaplayer](https://github.com/sedmelluq/lavaplayer) and [JDA](https://github.com/DV8FromTheWorld/JDA). | This wouldn't have been possible without the amazing folks behind [lavaplayer](https://github.com/sedmelluq/lavaplayer) and [JDA](https://github.com/DV8FromTheWorld/JDA). | ||||||
| And without ReperakDev and FoxShadew. Thank you. | And without ReperakDev and FoxShadew. Thank you. | ||||||
|  | @ -2,7 +2,6 @@ package codes.ztereohype.ztereomusic.audio; | ||||||
| 
 | 
 | ||||||
| import com.sedmelluq.discord.lavaplayer.player.AudioPlayer; | import com.sedmelluq.discord.lavaplayer.player.AudioPlayer; | ||||||
| import com.sedmelluq.discord.lavaplayer.track.playback.AudioFrame; | import com.sedmelluq.discord.lavaplayer.track.playback.AudioFrame; | ||||||
| //import com.sedmelluq.discord.lavaplayer.source.youtube.YoutubeAudioSourceManager; |  | ||||||
| import net.dv8tion.jda.api.audio.AudioSendHandler; | import net.dv8tion.jda.api.audio.AudioSendHandler; | ||||||
| 
 | 
 | ||||||
| import java.nio.ByteBuffer; | import java.nio.ByteBuffer; | ||||||
|  |  | ||||||
|  | @ -7,6 +7,7 @@ import com.sedmelluq.discord.lavaplayer.tools.FriendlyException; | ||||||
| import com.sedmelluq.discord.lavaplayer.track.AudioTrack; | import com.sedmelluq.discord.lavaplayer.track.AudioTrack; | ||||||
| import com.sedmelluq.discord.lavaplayer.track.AudioTrackEndReason; | import com.sedmelluq.discord.lavaplayer.track.AudioTrackEndReason; | ||||||
| import lombok.Getter; | import lombok.Getter; | ||||||
|  | import lombok.Setter; | ||||||
| import net.dv8tion.jda.api.entities.Guild; | import net.dv8tion.jda.api.entities.Guild; | ||||||
| import net.dv8tion.jda.api.entities.MessageChannel; | import net.dv8tion.jda.api.entities.MessageChannel; | ||||||
| 
 | 
 | ||||||
|  | @ -16,8 +17,9 @@ import java.util.List; | ||||||
| public class TrackManager extends AudioEventAdapter { | public class TrackManager extends AudioEventAdapter { | ||||||
|     private final @Getter AudioPlayer player; |     private final @Getter AudioPlayer player; | ||||||
|     public final List<AudioTrack> trackQueue = new ArrayList<>(); |     public final List<AudioTrack> trackQueue = new ArrayList<>(); | ||||||
|     private final MessageChannel infoChannel; |     private @Getter @Setter MessageChannel infoChannel; | ||||||
|     private final Guild guild; |     private final Guild guild; | ||||||
|  |     private boolean trackHasErrored = false; // this is a temporary workaround that helps me debug stuff. will be removed. | ||||||
| 
 | 
 | ||||||
|     public TrackManager(AudioPlayerManager playerManager, MessageChannel infoChannel, Guild guild) { |     public TrackManager(AudioPlayerManager playerManager, MessageChannel infoChannel, Guild guild) { | ||||||
|         this.player = playerManager.createPlayer(); |         this.player = playerManager.createPlayer(); | ||||||
|  | @ -110,10 +112,17 @@ public class TrackManager extends AudioEventAdapter { | ||||||
| 
 | 
 | ||||||
|     @Override |     @Override | ||||||
|     public void onTrackException(AudioPlayer player, AudioTrack track, FriendlyException exception) { |     public void onTrackException(AudioPlayer player, AudioTrack track, FriendlyException exception) { | ||||||
|         infoChannel.sendMessage("Uh oh, a track did something strange. Skipping...").queue(); |         System.out.println(exception.getMessage()); | ||||||
|         trackQueue.remove(track); | 
 | ||||||
|  |         if (!trackHasErrored) { | ||||||
|  |             infoChannel.sendMessage("Uh oh, a track did something strange. The error was: " + exception.getMessage() + ". Trying to replay...").queue(); | ||||||
|  |             player.playTrack(track); | ||||||
|  |         } else { | ||||||
|  |             infoChannel.sendMessage("The error happened again. Skipping...").queue(); | ||||||
|             playNext(); |             playNext(); | ||||||
|         } |         } | ||||||
|  |         trackHasErrored = !trackHasErrored; | ||||||
|  |     } | ||||||
| 
 | 
 | ||||||
|     @Override |     @Override | ||||||
|     public void onTrackStuck(AudioPlayer player, AudioTrack track, long thresholdMs) { |     public void onTrackStuck(AudioPlayer player, AudioTrack track, long thresholdMs) { | ||||||
|  |  | ||||||
|  | @ -2,14 +2,11 @@ package codes.ztereohype.ztereomusic.networking; | ||||||
| 
 | 
 | ||||||
| import codes.ztereohype.ztereomusic.ZtereoMUSIC; | import codes.ztereohype.ztereomusic.ZtereoMUSIC; | ||||||
| import net.shadew.json.Json; | import net.shadew.json.Json; | ||||||
| import net.shadew.json.JsonNode; |  | ||||||
| import net.shadew.json.JsonPath; | import net.shadew.json.JsonPath; | ||||||
| import net.shadew.json.JsonSyntaxException; | import net.shadew.json.JsonSyntaxException; | ||||||
| 
 | 
 | ||||||
| import java.io.IOException; | import java.io.IOException; | ||||||
| import java.io.InputStream; |  | ||||||
| import java.net.URL; | import java.net.URL; | ||||||
| import java.nio.charset.StandardCharsets; |  | ||||||
| import java.util.Optional; | import java.util.Optional; | ||||||
| 
 | 
 | ||||||
| public class YoutubeSearch { | public class YoutubeSearch { | ||||||
|  | @ -27,8 +24,10 @@ public class YoutubeSearch { | ||||||
|             e.printStackTrace(); |             e.printStackTrace(); | ||||||
|             return Optional.empty(); |             return Optional.empty(); | ||||||
|         } |         } | ||||||
|  | 
 | ||||||
|         JsonPath path = JsonPath.parse("items[0].id.videoId"); |         JsonPath path = JsonPath.parse("items[0].id.videoId"); | ||||||
| 
 | 
 | ||||||
|  |         //todo: actually check if there is a response before parsing directly to the response + get the music-related one with most views | ||||||
|         try { |         try { | ||||||
|             return Optional.ofNullable(JSON.parse(jsonResponse).query(path).asString()); |             return Optional.ofNullable(JSON.parse(jsonResponse).query(path).asString()); | ||||||
|         } catch (JsonSyntaxException e) { |         } catch (JsonSyntaxException e) { | ||||||
|  |  | ||||||
		Loading…
	
	Add table
		Add a link
		
	
		Reference in a new issue