/* * Copyright 2008-2013, ETH Zürich, Samuel Welten, Michael Kuhn, Tobias Langner, * Sandro Affentranger, Lukas Bossard, Michael Grob, Rahul Jain, * Dominic Langenegger, Sonia Mayor Alonso, Roger Odermatt, Tobias Schlueter, * Yannick Stucki, Sebastian Wendland, Samuel Zehnder, Samuel Zihlmann, * Samuel Zweifel * * This file is part of Jukefox. * * Jukefox is free software: you can redistribute it and/or modify it under the * terms of the GNU General Public License as published by the Free Software * Foundation, either version 3 of the License, or any later version. Jukefox is * distributed in the hope that it will be useful, but WITHOUT ANY WARRANTY; * without even the implied warranty of MERCHANTABILITY or FITNESS FOR A * PARTICULAR PURPOSE. See the GNU General Public License for more details. * * You should have received a copy of the GNU General Public License along with * Jukefox. If not, see <http://www.gnu.org/licenses/>. */ package ch.ethz.dcg.jukefox.model.providers; import java.io.File; import java.io.IOException; import ch.ethz.dcg.jukefox.commons.DataUnavailableException; import ch.ethz.dcg.jukefox.data.db.IDbDataPortal; import ch.ethz.dcg.jukefox.data.playlist.PlaylistReader; import ch.ethz.dcg.jukefox.data.playlist.PlaylistWriter; import ch.ethz.dcg.jukefox.manager.DirectoryManager; import ch.ethz.dcg.jukefox.model.collection.IReadOnlyPlaylist; import ch.ethz.dcg.jukefox.model.collection.Playlist; /** * Provides all possible data access options for playlist-objects */ public class PlayerPlaylistManager { private final IDbDataPortal dbDataPortal; private final DirectoryManager directoryManager; private final String playerModelName; /** * Creates a new instance of {@link PlayerPlaylistManager} * * @param dbDataPortal * The database data portal which will be used */ public PlayerPlaylistManager(IDbDataPortal dbDataPortal, String playModelName, DirectoryManager directoryManager) { this.dbDataPortal = dbDataPortal; this.directoryManager = directoryManager; this.playerModelName = playModelName; } /** * Loads a {@link Playlist} from a file with the given name * * @param name * The name ({@link String}) of the playlist file to be loaded * @return A {@link Playlist} from a file with the given name */ public Playlist loadPlaylistFromFileByName(String name) throws DataUnavailableException { Playlist playlist = null; try { playlist = PlaylistReader.loadPlaylistFromFileByName(directoryManager, dbDataPortal, name, playerModelName); } catch (IOException e) { throw new DataUnavailableException(e); } return playlist; } /** * Write a playlist into a file * * @param playlist * The {@link IReadOnlyPlaylist} to be saved * @param name * The name ({@link String}) of the {@link IReadOnlyPlaylist} * file to be saved */ public void writePlaylistToFile(IReadOnlyPlaylist playlist, String name) { PlaylistWriter.writePlaylist(directoryManager, dbDataPortal, playlist, name, playerModelName); } /** * Gets the playlist directory ({@link File}) */ public File getPlaylistDirectory() { return directoryManager.getPlaylistDirectory(playerModelName); } }