Merge branch 'yt-fix' into 'ms4/dev'

Fix Youtube playlists loading

See merge request morningstar/Arcturus-Community!2
This commit is contained in:
brenoepic 2022-12-21 14:07:02 +00:00
commit 3264fbba6e
2 changed files with 4 additions and 5 deletions

View File

@ -27,7 +27,7 @@ public class AddYoutubePlaylistCommand extends Command {
int itemId; int itemId;
try { try {
itemId = Integer.valueOf(params[1]); itemId = Integer.parseInt(params[1]);
} catch (NumberFormatException e) { } catch (NumberFormatException e) {
gameClient.getHabbo().whisper(Emulator.getTexts().getValue("commands.error.cmd_add_youtube_playlist.no_base_item")); gameClient.getHabbo().whisper(Emulator.getTexts().getValue("commands.error.cmd_add_youtube_playlist.no_base_item"));
return true; return true;
@ -45,7 +45,7 @@ public class AddYoutubePlaylistCommand extends Command {
return true; return true;
} }
Emulator.getGameEnvironment().getItemManager().getYoutubeManager().addPlaylistToItem(Integer.valueOf(params[1]), playlist); Emulator.getGameEnvironment().getItemManager().getYoutubeManager().addPlaylistToItem(Integer.parseInt(params[1]), playlist);
try (Connection connection = Emulator.getDatabase().getDataSource().getConnection(); PreparedStatement statement = connection.prepareStatement("INSERT INTO `youtube_playlists` (`item_id`, `playlist_id`) VALUES (?, ?)")) { try (Connection connection = Emulator.getDatabase().getDataSource().getConnection(); PreparedStatement statement = connection.prepareStatement("INSERT INTO `youtube_playlists` (`item_id`, `playlist_id`) VALUES (?, ?)")) {
statement.setInt(1, itemId); statement.setInt(1, itemId);

View File

@ -98,20 +98,19 @@ public class YoutubeManager {
final String playlistId = set.getString("playlist_id"); final String playlistId = set.getString("playlist_id");
youtubeDataLoaderPool.submit(() -> { youtubeDataLoaderPool.submit(() -> {
ArrayList<YoutubePlaylist> playlists = this.playlists.getOrDefault(itemId, new ArrayList<>());
YoutubePlaylist playlist; YoutubePlaylist playlist;
try { try {
playlist = this.getPlaylistDataById(playlistId); playlist = this.getPlaylistDataById(playlistId);
if (playlist != null) { if (playlist != null) {
playlists.add(playlist); this.addPlaylistToItem(itemId, playlist);
} }
} catch (IOException e) { } catch (IOException e) {
LOGGER.error("Failed to load YouTube playlist {} ERROR: {}", playlistId, e); LOGGER.error("Failed to load YouTube playlist {} ERROR: {}", playlistId, e);
} }
this.playlists.put(itemId, playlists);
}); });
} }
} }