/** * Copyright 2012-2013 Maciej Jaworski, Mariusz Kapcia, Paweł Kędzia, Mateusz Kubuszok * * <p>Licensed under the Apache License, Version 2.0 (the "License"); * you may not use this file except in compliance with the License. * You may obtain a copy of the License at</p> * * <p>http://www.apache.org/licenses/LICENSE-2.0</p> * * <p>Unless required by applicable law or agreed to in writing, software * distributed under the License is distributed on an "AS IS" BASIS, * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. * See the License for the specific language governing permissions and * limitations under the License.</p> */ package com.autoupdater.server.services; import java.util.List; import org.apache.log4j.Logger; import org.hibernate.criterion.Projections; import org.hibernate.criterion.Restrictions; import org.springframework.beans.factory.annotation.Autowired; import org.springframework.stereotype.Service; import org.springframework.transaction.annotation.Transactional; import com.autoupdater.server.models.Package; import com.autoupdater.server.models.Update; /** * Implementation of PackageService. * * @see com.autoupdater.server.services.PackageService */ @Service @Transactional public class PackageServiceImp extends AbstractHibernateService implements PackageService { /** * Service's logger. */ private static Logger logger = Logger.getLogger(PackageServiceImp.class); /** * Instance of UpdateService. */ @Autowired private UpdateService updateService; @Override public void persist(Package _package) { logger.debug("Attempting to persist Package: " + _package); getSession().persist(_package); logger.debug("Persisted Package: " + _package); } @Override public Package merge(Package _package) { logger.debug("Attempting to merge Package: " + _package); _package = (Package) getSession().merge(_package); logger.debug("Merged Package: " + _package); return _package; } @Override public void remove(Package _package) { logger.debug("Attempting to delete Package: " + _package); for (Update update : _package.getUpdates()) updateService.remove(update); getSession().delete(_package); logger.debug("Deleted Package: " + _package); } @Override public void refresh(Package _package) { logger.debug("Attempting to update Package: " + _package); getSession().update(_package); logger.debug("Updated Package: " + _package); } @Override public Package findById(int id) { logger.debug("Attempting to find Package by id: " + id); Package _package = (Package) getSession().createCriteria(Package.class) .add(Restrictions.eq("id", id)).uniqueResult(); logger.debug("Found Package, id: " + id); return _package; } @Override public List<Package> findAll() { logger.debug("Attempting to find all Packages"); List<Package> packages = getSession().createCriteria(Package.class).list(); logger.debug("Found all Packages: " + packages.size()); return packages; } @Override public List<String> findAllNames() { logger.debug("Attempting to find all Packages' names"); @SuppressWarnings({ "cast" }) List<String> names = (List<String>) getSession().createCriteria(Package.class) .setProjection(Projections.projectionList().add(Projections.property("name"))) .list(); logger.debug("Found all Packages' names: " + names.size()); return names; } }