com.ensa.model.controller.impl.ImageDAOImpl.java Source code

Java tutorial

Introduction

Here is the source code for com.ensa.model.controller.impl.ImageDAOImpl.java

Source

/*
 * To change this license header, choose License Headers in Project Properties.
 * To change this template file, choose Tools | Templates
 * and open the template in the editor.
 */
package com.ensa.model.controller.impl;

import com.ensa.model.Image;
import com.ensa.model.controller.ImageDao;
import java.util.ArrayList;
import java.util.List;
import org.hibernate.Query;
import org.hibernate.Session;
import org.hibernate.SessionFactory;
import org.hibernate.Transaction;
import org.slf4j.Logger;
import org.slf4j.LoggerFactory;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.stereotype.Repository;
import org.springframework.stereotype.Service;
import org.springframework.transaction.annotation.Transactional;

/**
 *
 * @author Iob
 */
@Repository
@Service
@Transactional
public class ImageDAOImpl implements ImageDao {

    private static final Logger logger = LoggerFactory.getLogger(ImageDAOImpl.class);

    @Autowired
    private SessionFactory sessionFactory;

    public void setSessionFactory(SessionFactory sf) {
        this.sessionFactory = sf;
    }

    @Override
    public void addImage(Image img) {
        Session session = this.sessionFactory.getCurrentSession();
        Transaction t = session.beginTransaction();
        session.persist(img);
        t.commit();
        logger.info("Image added successfully");
    }

    @Override
    public void updateImage(Image img) {
        throw new UnsupportedOperationException("Not supported yet."); //To change body of generated methods, choose Tools | Templates.
    }

    @Override
    public Image getImageById(int id) {
        String hql = "FROM Image I WHERE I.ID=:id";
        Session session = sessionFactory.getCurrentSession();
        Transaction transaction = null;
        try {
            Query query = session.createQuery(hql);
            transaction = session.beginTransaction();
            query.setParameter("ID ", id);
            List results = query.list();
            transaction.commit();
            if (results.isEmpty()) {
                return null;
            } else {
                return (Image) results.get(0);
            }
        } catch (Exception e) {
            e.printStackTrace();
            transaction.rollback();
            return null;
        }

    }

    @Override
    public List<Image> getAllImages() {
        String hql = "FROM Image";
        Session session = sessionFactory.getCurrentSession();
        Query query = session.createQuery(hql);
        query.setMaxResults(20);
        List results = query.list();

        if (results.isEmpty()) {
            return null;
        } else {
            return results;
        }

    }

    @Override
    public void removeImage(int id) {
    }

    @Override
    public List<Image> getLikedImages() {
        List<Image> liste = new ArrayList<Image>();
        Session session = this.sessionFactory.getCurrentSession();
        Query query = session.createQuery("FROM Image img ORDER BY img.likes asc");
        query.setMaxResults(100);
        liste = query.list();

        return liste;
    }

    public List<Image> getDownloadedImages() {
        List<Image> liste = new ArrayList<Image>();
        Session session = this.sessionFactory.getCurrentSession();
        Query query = session.createQuery("FROM Image img ORDER BY img.downloads asc");
        query.setMaxResults(100);
        liste = query.list();
        return liste;
    }

    @Override
    public List<Image> getPublicImages() {
        List<Image> liste = new ArrayList<Image>();
        Session session = this.sessionFactory.getCurrentSession();
        Query query = session.createQuery("FROM Image img WHERE img.pravacy='public'");
        query.setMaxResults(100);
        liste = query.list();
        return liste;
    }

}