de.steilerdev.myVerein.server.controller.ContentController.java Source code

Java tutorial

Introduction

Here is the source code for de.steilerdev.myVerein.server.controller.ContentController.java

Source

/**
 * Copyright (C) 2015 Frank Steiler <frank@steilerdev.de>
 *
 * This program 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 2 of the License, or
 * (at your option) any later version.
 *
 * This program 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 this program.  If not, see <http://www.gnu.org/licenses/>.
 */
package de.steilerdev.myVerein.server.controller;

import com.mongodb.gridfs.GridFSDBFile;
import de.steilerdev.myVerein.server.model.GridFSRepository;
import de.steilerdev.myVerein.server.model.Settings;
import de.steilerdev.myVerein.server.model.SettingsRepository;
import de.steilerdev.myVerein.server.model.User;
import de.steilerdev.myVerein.server.security.CurrentUser;
import org.apache.commons.io.IOUtils;
import org.slf4j.Logger;
import org.slf4j.LoggerFactory;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.core.io.ClassPathResource;
import org.springframework.http.HttpStatus;
import org.springframework.http.ResponseEntity;
import org.springframework.stereotype.Controller;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.RequestMethod;
import org.springframework.web.bind.annotation.RequestParam;
import org.springframework.web.bind.annotation.ResponseBody;

import java.io.IOException;

/**
 * This controller is used to server files or information stored within the database or settings file.
 */
@Controller
@RequestMapping("/content")
public class ContentController {
    private static Logger logger = LoggerFactory.getLogger(ContentController.class);

    @Autowired
    GridFSRepository gridFSRepository;

    @Autowired
    SettingsRepository settingsRepository;

    /**
     * This function gathers the club logo either from the database or the classpath, depending if the user uploaded a custom logo. The function is invoked by GETting the URI /content/clubLogo.
     * @param defaultLogo If this parameter is present the method will return the default logo, without searching through the database.
     * @return The current club logo as byte array.
     */
    @RequestMapping(value = "clubLogo", produces = "image/png", method = RequestMethod.GET)
    @ResponseBody
    ResponseEntity<byte[]> getClubLogo(@RequestParam(required = false) String defaultLogo) {
        logger.trace("Loading club logo");
        GridFSDBFile clubLogo = null;
        if (defaultLogo == null) {
            //Loading file only from database if the request did not state the fact to use the default logo.
            clubLogo = gridFSRepository.findClubLogo();
        } else {
            logger.info("Directly loading default club logo");
        }

        if (clubLogo == null) {
            if (defaultLogo == null) {
                logger.info("No club logo found, using default logo");
            }

            try {
                return new ResponseEntity<>(
                        IOUtils.toByteArray(new ClassPathResource("content/Logo.png").getInputStream()),
                        HttpStatus.OK);
            } catch (IOException e) {
                logger.warn("Unable to load default logo: " + e.getMessage());
                return new ResponseEntity<>(HttpStatus.INTERNAL_SERVER_ERROR);
            }
        } else {
            logger.debug("Loading club logo from database");
            try {
                return new ResponseEntity<>(IOUtils.toByteArray(clubLogo.getInputStream()), HttpStatus.OK);
            } catch (IOException e) {
                logger.warn("Unable to load club logo from database: " + e.getMessage());
                return new ResponseEntity<>(HttpStatus.INTERNAL_SERVER_ERROR);
            }
        }
    }

    /**
     * This function deletes the currently stored club logo. This action can only be performed by the super admin. The function is invoked by DELETEing the URI /content/clubLogo.
     * @param currentUser The currently logged in user.
     * @return An HTTP response with a status code. If an error occurred an error message is bundled into the response, otherwise a success message is available.
     */
    @RequestMapping(value = "clubLogo", method = RequestMethod.DELETE)
    public @ResponseBody ResponseEntity<String> deleteClubLogo(@CurrentUser User currentUser) {
        if (currentUser == null) {
            logger.warn("An unauthenticated user tries to delete the club logo");
            return new ResponseEntity<>("You are not allowed to perform this action, please log in first",
                    HttpStatus.FORBIDDEN);
        } else if (!currentUser.isSuperAdmin()) {
            logger.warn("A non-super admin tries to delete the club logo: " + currentUser.getEmail());
            return new ResponseEntity<>("You are not allowed to perform this action", HttpStatus.FORBIDDEN);
        } else if (gridFSRepository.findClubLogo() == null) {
            logger.warn("Unable to delete club logo, because it is not available");
            return new ResponseEntity<>("No club logo there to delete", HttpStatus.BAD_REQUEST);
        } else {
            gridFSRepository.deleteCurrentClubLogo();
            logger.info("Successfully delete the club logo");
            return new ResponseEntity<>("Successfully delete the club logo", HttpStatus.OK);
        }
    }

    /**
     * This function gathers the name of the club defined within the properties file. The function is invoked by GETting the URI /content/clubName.
     * @return An HTTP response with a status code. If an error occurred an error message is bundled into the response, otherwise the name of the club.
     */
    @RequestMapping(value = "clubName", method = RequestMethod.GET)
    @ResponseBody
    ResponseEntity<String> getClubName() {
        logger.trace("Gathering club name");
        String clubName = Settings.loadSettings(settingsRepository).getClubName();
        if (clubName == null || clubName.isEmpty()) {
            logger.warn("Unable to get club name");
            return new ResponseEntity<>("Unable to get club name", HttpStatus.INTERNAL_SERVER_ERROR);
        } else {
            logger.debug("Returning club name " + clubName);
            return new ResponseEntity<>(clubName, HttpStatus.OK);
        }
    }
}