/*
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.theme;
import org.libresonic.player.domain.Theme;
import org.libresonic.player.domain.UserSettings;
import org.libresonic.player.service.SecurityService;
import org.libresonic.player.service.SettingsService;
import org.springframework.web.servlet.ThemeResolver;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;
import java.util.HashSet;
import java.util.Set;
/**
* Theme resolver implementation which returns the theme selected in the settings.
*
* @author Sindre Mehus
*/
public class LibresonicThemeResolver implements ThemeResolver {
private SecurityService securityService;
private SettingsService settingsService;
private Set<String> themeIds;
/**
* Resolve the current theme name via the given request.
*
* @param request Request to be used for resolution
* @return The current theme name
*/
public String resolveThemeName(HttpServletRequest request) {
String themeId = (String) request.getAttribute("libresonic.theme");
if (themeId != null) {
return themeId;
}
// Optimization: Cache theme in the request.
themeId = doResolveThemeName(request);
request.setAttribute("libresonic.theme", themeId);
return themeId;
}
private String doResolveThemeName(HttpServletRequest request) {
String themeId = null;
// Look for user-specific theme.
String username = securityService.getCurrentUsername(request);
if (username != null) {
UserSettings userSettings = settingsService.getUserSettings(username);
if (userSettings != null) {
themeId = userSettings.getThemeId();
}
}
if (themeId != null && themeExists(themeId)) {
return themeId;
}
// Return system theme.
themeId = settingsService.getThemeId();
return themeExists(themeId) ? themeId : "default";
}
/**
* Returns whether the theme with the given ID exists.
* @param themeId The theme ID.
* @return Whether the theme with the given ID exists.
*/
private synchronized boolean themeExists(String themeId) {
// Lazily create set of theme IDs.
if (themeIds == null) {
themeIds = new HashSet<String>();
Theme[] themes = settingsService.getAvailableThemes();
for (Theme theme : themes) {
themeIds.add(theme.getId());
}
}
return themeIds.contains(themeId);
}
/**
* Set the current theme name to the given one. This method is not supported.
*
* @param request Request to be used for theme name modification
* @param response Response to be used for theme name modification
* @param themeName The new theme name
* @throws UnsupportedOperationException If the ThemeResolver implementation
* does not support dynamic changing of the theme
*/
public void setThemeName(HttpServletRequest request, HttpServletResponse response, String themeName) {
throw new UnsupportedOperationException("Cannot change theme - use a different theme resolution strategy");
}
public void setSecurityService(SecurityService securityService) {
this.securityService = securityService;
}
public void setSettingsService(SettingsService settingsService) {
this.settingsService = settingsService;
}
}