SimpleHorseService.java 2.5 KB
Newer Older
1 2 3
package at.ac.tuwien.sepm.assignment.individual.service.impl;

import at.ac.tuwien.sepm.assignment.individual.entity.Horse;
4
import at.ac.tuwien.sepm.assignment.individual.exception.NotFoundException;
5
import at.ac.tuwien.sepm.assignment.individual.persistence.FileDao;
6 7 8 9 10 11 12 13 14
import at.ac.tuwien.sepm.assignment.individual.persistence.HorseDao;
import at.ac.tuwien.sepm.assignment.individual.service.HorseService;
import at.ac.tuwien.sepm.assignment.individual.util.ValidationException;
import at.ac.tuwien.sepm.assignment.individual.util.Validator;
import org.slf4j.Logger;
import org.slf4j.LoggerFactory;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.dao.DataAccessException;
import org.springframework.stereotype.Service;
15
import org.springframework.web.multipart.MultipartFile;
16

17
import java.io.IOException;
18 19 20 21 22
import java.lang.invoke.MethodHandles;

@Service
public class SimpleHorseService implements HorseService {
    private static final Logger LOGGER = LoggerFactory.getLogger(MethodHandles.lookup().lookupClass());
23 24
    private final HorseDao horseJdbcDao;
    private final FileDao horseFileDao;
25 26 27
    private final Validator validator;

    @Autowired
28 29 30
    public SimpleHorseService(HorseDao horseJdbcDao, FileDao horseFileDao, Validator validator) {
        this.horseJdbcDao = horseJdbcDao;
        this.horseFileDao = horseFileDao;
31 32 33 34 35 36
        this.validator = validator;
    }

    @Override
    public Horse findOneById(Long id) {
        LOGGER.trace("findOneById({})", id);
37
        return horseJdbcDao.findOneById(id);
38 39 40 41 42
    }

    @Override
    public Horse addHorse(Horse horse) throws ValidationException, DataAccessException {
        this.validator.validateNewHorse(horse);
43
        LOGGER.trace("addHorse({})", horse.toString());
44 45 46
        return horseJdbcDao.addHorse(horse);
    }

47
    @Override
48
    public Horse updateHorse(Horse horse) throws ValidationException, DataAccessException, IOException {
49 50 51 52 53
        this.validator.validateUpdateHorse(horse);
        LOGGER.trace("updateHorse({})", horse.toString());
        return horseJdbcDao.updateHorse(horse);
    }

54 55 56 57 58 59
    @Override
    public void deleteHorse(Long id) throws NotFoundException, DataAccessException, IOException {
        LOGGER.trace("deleteHorse({})", id);
        horseJdbcDao.deleteHorse(id);
    }

60 61 62 63 64
    @Override
    public void saveImage(MultipartFile img) throws ValidationException, IOException {
        this.validator.validateHorseImage(img);
        LOGGER.trace("saveImage({})", img.getName());
        horseFileDao.save(img);
65 66
    }
}