import javax.servlet.http.HttpServletResponse;
import net.pterodactylus.demoscenemusic.data.Artist;
+import net.pterodactylus.demoscenemusic.data.Properties;
+import net.pterodactylus.demoscenemusic.data.Style;
+import net.pterodactylus.demoscenemusic.data.Track;
+import net.pterodactylus.demoscenemusic.data.TrackDerivative;
+import net.pterodactylus.demoscenemusic.data.User;
import net.pterodactylus.demoscenemusic.page.ServletRequest;
+import net.pterodactylus.demoscenemusic.template.PropertiesAccessor;
+import net.pterodactylus.demoscenemusic.template.TrackDerivativeAccessor;
+import net.pterodactylus.demoscenemusic.template.UserAccessor;
import net.pterodactylus.util.io.Closer;
import net.pterodactylus.util.io.StreamCopier;
import net.pterodactylus.util.template.ClassPathTemplateProvider;
core = (Core) config.getServletContext().getAttribute("core");
templateContextFactory.addAccessor(Object.class, new ReflectionAccessor());
+ templateContextFactory.addAccessor(User.class, new UserAccessor());
+ templateContextFactory.addAccessor(Properties.class, new PropertiesAccessor());
+ templateContextFactory.addAccessor(TrackDerivative.class, new TrackDerivativeAccessor());
templateContextFactory.addFilter("html", new HtmlFilter());
CollectionSortFilter sortFilter = new CollectionSortFilter();
@Override
public int compare(Artist leftArtist, Artist rightArtist) {
- return leftArtist.name().compareToIgnoreCase(rightArtist.name());
+ return leftArtist.getName().compareToIgnoreCase(rightArtist.getName());
+ }
+
+ });
+ sortFilter.addComparator(Track.class, new Comparator<Track>() {
+
+ @Override
+ public int compare(Track leftTrack, Track rightTrack) {
+ return leftTrack.getName().compareToIgnoreCase(rightTrack.getName());
+ }
+
+ });
+ sortFilter.addComparator(Style.class, new Comparator<Style>() {
+
+ @Override
+ public int compare(Style leftStyle, Style rightStyle) {
+ return leftStyle.getName().compareToIgnoreCase(rightStyle.getName());
}
});
*/
@Override
protected void doGet(HttpServletRequest request, HttpServletResponse httpServletResponse) throws ServletException, IOException {
+ request.setCharacterEncoding("UTF-8");
String path = request.getPathInfo();
if (path.startsWith("/")) {
path = path.substring(1);
}
+ if ((path.length() == 0) || (path.endsWith("/"))) {
+ path += "index";
+ }
Page<ServletRequest> page = pages.get(path);
if (page != null) {
ServletRequest servletRequest;
try {
- servletRequest = new ServletRequest(request);
+ servletRequest = new ServletRequest(request, this);
} catch (URISyntaxException use1) {
throw new IOException("Could not create URI from " + request.getRequestURI(), use1);
}
}
}
+ /**
+ * {@inheritDoc}
+ */
+ @Override
+ protected void doPost(HttpServletRequest httpServletRequest, HttpServletResponse httpServletResponse) throws ServletException, IOException {
+ doGet(httpServletRequest, httpServletResponse);
+ }
+
//
// PRIVATE METHODS
//