docs/docs-core/src/main/java/com/sismics/docs/core/dao/jpa/FileDao.java

162 lines
4.7 KiB
Java
Raw Normal View History

2013-07-27 18:33:20 +02:00
package com.sismics.docs.core.dao.jpa;
import java.util.Date;
import java.util.List;
import java.util.UUID;
2013-07-27 18:33:20 +02:00
import javax.persistence.EntityManager;
import javax.persistence.NoResultException;
import javax.persistence.Query;
import com.sismics.docs.core.constant.AuditLogType;
import com.sismics.docs.core.model.jpa.File;
import com.sismics.docs.core.util.AuditLogUtil;
import com.sismics.util.context.ThreadLocalContext;
2013-07-27 18:33:20 +02:00
/**
* File DAO.
*
* @author bgamard
*/
public class FileDao {
/**
* Creates a new file.
*
* @param file File
* @return New ID
* @throws Exception
*/
public String create(File file) {
// Create the UUID
file.setId(UUID.randomUUID().toString());
// Create the file
EntityManager em = ThreadLocalContext.get().getEntityManager();
file.setCreateDate(new Date());
em.persist(file);
// Create audit log
AuditLogUtil.create(file, AuditLogType.CREATE);
2013-07-27 18:33:20 +02:00
return file.getId();
}
/**
* Returns the list of all files.
*
* @return List of files
*/
@SuppressWarnings("unchecked")
public List<File> findAll() {
EntityManager em = ThreadLocalContext.get().getEntityManager();
Query q = em.createQuery("select f from File f where f.deleteDate is null");
return q.getResultList();
}
2013-07-27 18:33:20 +02:00
/**
* Returns an active file.
*
* @param id File ID
* @return Document
*/
public File getFile(String id) {
EntityManager em = ThreadLocalContext.get().getEntityManager();
Query q = em.createQuery("select f from File f where f.id = :id and f.deleteDate is null");
q.setParameter("id", id);
return (File) q.getSingleResult();
}
/**
* Returns an active file.
*
* @param id File ID
* @param userId User ID
* @return Document
*/
public File getFile(String id, String userId) {
EntityManager em = ThreadLocalContext.get().getEntityManager();
Query q = em.createQuery("select f from File f where f.id = :id and f.userId = :userId and f.deleteDate is null");
q.setParameter("id", id);
q.setParameter("userId", userId);
return (File) q.getSingleResult();
}
2013-07-27 18:33:20 +02:00
/**
* Deletes a file.
*
* @param id File ID
*/
public void delete(String id) {
EntityManager em = ThreadLocalContext.get().getEntityManager();
2013-08-13 23:15:58 +02:00
// Get the file
2013-07-27 18:33:20 +02:00
Query q = em.createQuery("select f from File f where f.id = :id and f.deleteDate is null");
q.setParameter("id", id);
File fileDb = (File) q.getSingleResult();
2013-08-13 23:15:58 +02:00
// Delete the file
2013-07-27 18:33:20 +02:00
Date dateNow = new Date();
fileDb.setDeleteDate(dateNow);
// Create audit log
AuditLogUtil.create(fileDb, AuditLogType.DELETE);
2013-07-27 18:33:20 +02:00
}
/**
2015-03-06 21:13:09 +01:00
* Update a file.
*
* @param file File to update
* @return Updated file
*/
2015-03-06 21:13:09 +01:00
public File update(File file) {
EntityManager em = ThreadLocalContext.get().getEntityManager();
// Get the file
Query q = em.createQuery("select f from File f where f.id = :id and f.deleteDate is null");
q.setParameter("id", file.getId());
File fileFromDb = (File) q.getSingleResult();
// Update the file
fileFromDb.setDocumentId(file.getDocumentId());
2015-03-06 21:13:09 +01:00
fileFromDb.setContent(file.getContent());
fileFromDb.setOrder(file.getOrder());
return file;
}
2013-07-27 18:33:20 +02:00
/**
* Gets a file by its ID.
*
2013-08-13 23:15:58 +02:00
* @param id File ID
* @return File
2013-07-27 18:33:20 +02:00
*/
public File getById(String id) {
EntityManager em = ThreadLocalContext.get().getEntityManager();
try {
return em.find(File.class, id);
} catch (NoResultException e) {
return null;
}
}
/**
* Get files by document ID or all orphan files of an user.
2013-07-27 18:33:20 +02:00
*
* @parma userId User ID
2013-07-27 18:33:20 +02:00
* @param documentId Document ID
* @return List of files
*/
@SuppressWarnings("unchecked")
public List<File> getByDocumentId(String userId, String documentId) {
2013-07-27 18:33:20 +02:00
EntityManager em = ThreadLocalContext.get().getEntityManager();
2015-03-06 21:23:50 +01:00
if (documentId == null) {
Query q = em.createQuery("select f from File f where f.documentId is null and f.deleteDate is null and f.userId = :userId order by f.createDate asc");
q.setParameter("userId", userId);
2015-03-06 21:23:50 +01:00
return q.getResultList();
}
2013-08-03 20:19:02 +02:00
Query q = em.createQuery("select f from File f where f.documentId = :documentId and f.deleteDate is null order by f.order asc");
2013-07-27 18:33:20 +02:00
q.setParameter("documentId", documentId);
2013-08-03 00:53:58 +02:00
return q.getResultList();
2013-07-27 18:33:20 +02:00
}
}