/* * 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.util.List; import ch.ethz.dcg.jukefox.commons.DataUnavailableException; import ch.ethz.dcg.jukefox.data.db.IDbDataPortal; import ch.ethz.dcg.jukefox.model.collection.BaseArtist; import ch.ethz.dcg.jukefox.model.collection.CompleteArtist; import ch.ethz.dcg.jukefox.model.collection.Genre; /** * Provides all possible data access options for artist-objects */ public class ArtistProvider { private final IDbDataPortal dbDataPortal; /** * Creates a new instance of {@link ArtistProvider} * * @param dbDataPortal * The database data portal which will be used */ public ArtistProvider(IDbDataPortal dbDataPortal) { this.dbDataPortal = dbDataPortal; } // ----- BASE ARTIST ----- /** * Gets a list of all available {@link BaseArtist} * * @return A list of all available {@link BaseArtist} */ public List<BaseArtist> getAllArtists() { return dbDataPortal.getAllArtists(); } /** * Gets a list of {@link BaseArtist} of the given {@link Genre} * * @param genre * The {@link Genre} of which you want generate the list of * {@link BaseArtist} * @return A list of {@link BaseArtist} of the given {@link Genre} */ public List<BaseArtist> getAllArtists(Genre genre) { return dbDataPortal.getArtistsForGenre(genre); } /** * Gets a list of {@link BaseArtist} searched by a search term * * @param searchTerm * The search term ({@link String}) that describes the desired * return value * @param maxResults * The maximum numbers ({@link Integer}) of results * @return All results as a list of {@link BaseArtist} of the given search * terms */ public List<BaseArtist> findBaseArtistBySearchString(String searchTerm, int maxResults) { return dbDataPortal.findArtistBySearchString(searchTerm, maxResults); } /** * Gets a list of famous {@link BaseArtist} searched by a search term * * @param searchTerm * The search term ({@link String}) that describes the desired * return value * @param maxResults * The maximum numbers ({@link Integer}) of results * @return All results as a list of {@link BaseArtist} of the given search * terms */ public List<BaseArtist> findFamousBaseArtistBySearchString(String searchTerm, int maxResults) { return dbDataPortal.findFamousArtistBySearchString(searchTerm, maxResults); } // ----- COMPLETE ARTIST ----- /** * Gets a {@link CompleteArtist} of a given {@link BaseArtist} * * @param album * A {@link BaseArtist} on which the returned * {@link CompleteArtist} will be based * @return A {@link CompleteArtist} of the given {@link BaseArtist} */ public CompleteArtist getCompleteArtist(BaseArtist baseArtist) throws DataUnavailableException { return dbDataPortal.getCompleteArtist(baseArtist); } }