/* This file is part of Libresonic. Libresonic 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 (at your option) any later version. Libresonic 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 Libresonic. If not, see <http://www.gnu.org/licenses/>. Copyright 2016 (C) Libresonic Authors Based upon Subsonic, Copyright 2009 (C) Sindre Mehus */ package org.libresonic.player.service; import org.libresonic.player.dao.RatingDao; import org.libresonic.player.domain.MediaFile; import org.libresonic.player.domain.MusicFolder; import org.libresonic.player.util.FileUtil; import java.io.File; import java.util.ArrayList; import java.util.List; /** * Provides services for user ratings. * * @author Sindre Mehus */ public class RatingService { private RatingDao ratingDao; private SecurityService securityService; private MediaFileService mediaFileService; /** * Returns the highest rated albums. * * @param offset Number of albums to skip. * @param count Maximum number of albums to return. * @param musicFolders Only return albums in these folders. * @return The highest rated albums. */ public List<MediaFile> getHighestRatedAlbums(int offset, int count, List<MusicFolder> musicFolders) { List<String> highestRated = ratingDao.getHighestRatedAlbums(offset, count, musicFolders); List<MediaFile> result = new ArrayList<MediaFile>(); for (String path : highestRated) { File file = new File(path); if (FileUtil.exists(file) && securityService.isReadAllowed(file)) { result.add(mediaFileService.getMediaFile(path)); } } return result; } /** * Sets the rating for a music file and a given user. * * @param username The user name. * @param mediaFile The music file. * @param rating The rating between 1 and 5, or <code>null</code> to remove the rating. */ public void setRatingForUser(String username, MediaFile mediaFile, Integer rating) { ratingDao.setRatingForUser(username, mediaFile, rating); } /** * Returns the average rating for the given music file. * * @param mediaFile The music file. * @return The average rating, or <code>null</code> if no ratings are set. */ public Double getAverageRating(MediaFile mediaFile) { return ratingDao.getAverageRating(mediaFile); } /** * Returns the rating for the given user and music file. * * @param username The user name. * @param mediaFile The music file. * @return The rating, or <code>null</code> if no rating is set. */ public Integer getRatingForUser(String username, MediaFile mediaFile) { return ratingDao.getRatingForUser(username, mediaFile); } public int getRatedAlbumCount(String username, List<MusicFolder> musicFolders) { return ratingDao.getRatedAlbumCount(username, musicFolders); } public void setRatingDao(RatingDao ratingDao) { this.ratingDao = ratingDao; } public void setSecurityService(SecurityService securityService) { this.securityService = securityService; } public void setMediaFileService(MediaFileService mediaFileService) { this.mediaFileService = mediaFileService; } }