org.sakaiproject.tool.assessment.facade.QuestionPoolFacadeQueries Maven / Gradle / Ivy
/**********************************************************************************
* $URL$
* $Id$
***********************************************************************************
*
* Copyright (c) 2004, 2005, 2006, 2007, 2008, 2009 The Sakai Foundation
*
* Licensed under the Educational Community 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
*
* http://www.opensource.org/licenses/ECL-2.0
*
* 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.
*
**********************************************************************************/
package org.sakaiproject.tool.assessment.facade;
import java.util.ArrayList;
import java.util.Collection;
import java.util.Collections;
import java.util.Date;
import java.util.HashMap;
import java.util.HashSet;
import java.util.Iterator;
import java.util.List;
import java.util.Map;
import java.util.Set;
import java.util.Vector;
import java.util.stream.Collectors;
import org.hibernate.Session;
import org.hibernate.query.Query;
import org.sakaiproject.component.cover.ComponentManager;
import org.sakaiproject.event.cover.EventTrackingService;
import org.sakaiproject.samigo.util.SamigoConstants;
import org.sakaiproject.tool.assessment.data.dao.assessment.Answer;
import org.sakaiproject.tool.assessment.data.dao.assessment.AnswerFeedback;
import org.sakaiproject.tool.assessment.data.dao.assessment.ItemData;
import org.sakaiproject.tool.assessment.data.dao.assessment.ItemMetaData;
import org.sakaiproject.tool.assessment.data.dao.assessment.ItemTag;
import org.sakaiproject.tool.assessment.data.dao.assessment.ItemText;
import org.sakaiproject.tool.assessment.data.dao.questionpool.QuestionPoolAccessData;
import org.sakaiproject.tool.assessment.data.dao.questionpool.QuestionPoolData;
import org.sakaiproject.tool.assessment.data.dao.questionpool.QuestionPoolItemData;
import org.sakaiproject.tool.assessment.data.ifc.assessment.ItemDataIfc;
import org.sakaiproject.tool.assessment.data.ifc.assessment.ItemMetaDataIfc;
import org.sakaiproject.tool.assessment.data.model.Tree;
import org.sakaiproject.tool.assessment.osid.shared.impl.IdImpl;
import org.sakaiproject.tool.assessment.services.ItemService;
import org.sakaiproject.tool.assessment.services.PersistenceService;
import org.sakaiproject.tool.assessment.services.assessment.AssessmentService;
import org.sakaiproject.util.api.FormattedText;
import org.springframework.dao.DataAccessException;
import org.springframework.orm.hibernate5.HibernateCallback;
import org.springframework.orm.hibernate5.support.HibernateDaoSupport;
import lombok.extern.slf4j.Slf4j;
@Slf4j
public class QuestionPoolFacadeQueries
extends HibernateDaoSupport implements QuestionPoolFacadeQueriesAPI {
// SAM-2499
private final FormattedText formattedText = (FormattedText) ComponentManager.get( FormattedText.class );
public QuestionPoolFacadeQueries() {
}
public IdImpl getQuestionPoolId(String id) {
return new IdImpl(id);
}
public IdImpl getQuestionPoolId(Long id) {
return new IdImpl(id);
}
public IdImpl getQuestionPoolId(long id) {
return new IdImpl(id);
}
/**
* Get a list of all the pools in the site. Note that questions in each pool will not
* be populated. We must keep this list updated.
*/
public List getAllPools() {
return (List) getHibernateTemplate().find("from QuestionPoolData");
}
public List getAllPoolsByAgent(final String agentId) {
final HibernateCallback hcb = session -> {
Query q = session.createQuery("from QuestionPoolData a where a.questionPoolId in (select ac.questionPoolId from QuestionPoolAccessData ac where agentId = :agent) ");
q.setParameter("agent", agentId);
return q.list();
};
List list = getHibernateTemplate().execute(hcb);
return list;
}
/**
* Get all the pools that the agent has access to. The easiest way seems to be
* #1. get all the existing pool
* #2. get all the QuestionPoolAccessData record of the agent
* #3. go through the existing pools and check it against the QuestionPoolAccessData (qpa) record to see if
* the agent is granted access to it. qpa record (if exists) always trumps the default access right set
* up for a pool
* e.g. if the defaultAccessType for a pool is ACCESS_DENIED but the qpa record say ADMIN, then access=ADMIN
* e.g. if the defaultAccessType for a pool is ADMIN but the qpa record say ACCESS_DENIED, then access=ACCESS_DENIED
* e.g. if no qpa record exists, then access rule will follow the defaultAccessType set by the pool
*/
public QuestionPoolIteratorFacade getAllPools(String agentId) {
List qpList = new ArrayList();
// #1.
// lydial: 9/22/05 we are not really using QuestionPoolAccessData, so filter by ownerid
//List poolList = getAllPools();
HibernateCallback> hcb = session -> session
.createQuery("from QuestionPoolData a where a.ownerId = :id")
.setParameter("id", agentId)
.list();
List poolList = getHibernateTemplate().execute(hcb);
/*
// #2. get all the QuestionPoolAccessData record belonging to the agent
List questionPoolAccessList = getHibernateTemplate().find(
"from QuestionPoolAccessData as qpa where qpa.agentId=?",
new Object[] {agentId}
, new org.hibernate.type.Type[] {Hibernate.STRING});
HashMap h = new HashMap(); // prepare a hashMap with (poolId, qpa)
Iterator i = questionPoolAccessList.iterator();
while (i.hasNext()) {
QuestionPoolAccessData qpa = (QuestionPoolAccessData) i.next();
h.put(qpa.getQuestionPoolId(), qpa);
}
// #3. We need to go through the existing QuestionPool and the QuestionPoolAccessData record
// to determine the access type
*/
try {
// counts is a hashmap going from poolid to number of subpools. It is significantly
// faster to build this with a single SQL query and then look up data in it.
Map counts = getSubPoolSizes(agentId).stream().collect(Collectors.toMap(pool -> pool[0], pool -> pool[1]));
for (QuestionPoolData qpp : poolList) {
// I really wish we don't need to populate the questionpool size & subpool size for JSF
// watch this for performance. hope Hibernate is smart enough not to load the entire question
// - daisy, 10/04/04
// populateQuestionPoolItemDatas(qpp);
// lookup number of subpools for this pool in our handy hash table
Long subPoolSize = counts.get(qpp.getQuestionPoolId());
qpp.setSubPoolSize(subPoolSize == null ? 0L : subPoolSize);
qpList.add(getQuestionPool(qpp));
}
}
catch (Exception e) {
log.warn(e.getMessage());
}
return new QuestionPoolIteratorFacade(qpList);
}
public QuestionPoolIteratorFacade getAllPoolsWithAccess(String agentId) {
List qpList = new ArrayList();
// First get the size of all pools in one query
Map counts = getSubPoolSizes(agentId).stream().collect(Collectors.toMap(pool -> pool[0], pool -> pool[1]));
List poolList = getAllPoolsByAgent(agentId);
try {
Iterator j = poolList.iterator();
while (j.hasNext()) {
QuestionPoolData qpp = (QuestionPoolData) j.next();
qpp.setSubPoolSize(counts.get(qpp.getQuestionPoolId()));
qpList.add(getQuestionPool(qpp));
}
}
catch (Exception e) {
log.warn("Error in getAllPoolsWithAccess: " + e.getMessage(), e);
}
return new QuestionPoolIteratorFacade(qpList);
}
public List getBasicInfoOfAllPools(final String agentId) {
final HibernateCallback hcb = session -> {
Query q = session.createQuery(
"select new QuestionPoolData(a.questionPoolId, a.title, a.parentPoolId)from QuestionPoolData a where a.questionPoolId " +
"in (select ac.questionPoolId from QuestionPoolAccessData ac where agentId = :agent)");
q.setParameter("agent", agentId);
return q.list();
};
List list = getHibernateTemplate().execute(hcb);
List poolList = new ArrayList();
for (int i = 0; i < list.size(); i++) {
QuestionPoolData a = (QuestionPoolData) list.get(i);
QuestionPoolFacade f = new QuestionPoolFacade(a.getQuestionPoolId(), a.getTitle(), a.getParentPoolId());
poolList.add(f);
}
return poolList;
}
private QuestionPoolFacade getQuestionPool(QuestionPoolData qpp) {
try {
return new QuestionPoolFacade(qpp);
}
catch (Exception e) {
log.warn(e.getMessage());
return null;
}
}
private List getAllItemsInThisPoolOnlyAndDetachFromAssessment(final Long questionPoolId) {
// return items that belong to this pool and this pool only. These items can not be part of any assessment either.
List list = getAllItemsInThisPoolOnly(questionPoolId);
List newlist = new ArrayList();
for (int i = 0; i < list.size(); i++) {
ItemData itemdata = (ItemData) list.get(i);
if (itemdata.getSection()==null ) {
// these items do not belong to any assessments, so add them to the list
newlist.add(itemdata);
}
else {
// do not add these items to the list, but we need to remove the POOLID metadata
// this item still links to an assessment
// remove this item's POOLID itemmetadata
itemdata.removeMetaDataByType(ItemMetaDataIfc.POOLID);
getHibernateTemplate().saveOrUpdate(itemdata); //save itemdata after removing metadata
}
}
return newlist;
}
private List getAllItemsInThisPoolOnly(final Long questionPoolId) {
// return items that belong to this pool and this pool only.
final HibernateCallback hcb = session -> {
Query q = session.createQuery("select ab from ItemData ab, QuestionPoolItemData qpi where ab.itemId=qpi.itemId and qpi.questionPoolId = :id");
q.setParameter("id", questionPoolId);
return q.list();
};
List list = getHibernateTemplate().execute(hcb);
List newlist = new ArrayList();
for (int i = 0; i < list.size(); i++) {
ItemData itemdata = (ItemData) list.get(i);
if (getPoolIdsByItem(itemdata.getItemId()).size() == 1) {
newlist.add(itemdata);
}
else {
// this item still links to other pool(s)
}
}
return newlist;
}
public List getAllItems(final Long questionPoolId) {
final HibernateCallback hcb = session -> {
Query q = session.createQuery("select ab from ItemData ab, QuestionPoolItemData qpi where ab.itemId=qpi.itemId and qpi.questionPoolId = :id order by ab.itemId");
q.setParameter("id", questionPoolId.longValue());
return q.list();
};
List list = getHibernateTemplate().execute(hcb);
return list;
}
public List getAllItemsIds(final Long questionPoolId) {
final HibernateCallback hcb = session -> {
Query q = session.createQuery("select qpi.itemId from QuestionPoolItemData qpi where qpi.questionPoolId = :questionPoolId");
q.setParameter("questionPoolId", questionPoolId.longValue());
return q.list();
};
List list = getHibernateTemplate().execute(hcb);
return list;
}
public List getAllItemFacadesOrderByItemText(final Long questionPoolId,
final String orderBy, final String ascending) {
// Fixed for bug 3559
log.debug("QuestionPoolFacadeQueries: getAllItemFacadesOrderByItemText:: orderBy = {}", orderBy);
List list = getAllItems(questionPoolId);
log.debug("QuestionPoolFacadeQueries: getAllItemFacadesOrderByItemText:: size = {}", list.size());
Map hp = new HashMap();
Vector origValueV;
ItemData itemData;
ItemFacade itemFacade;
Vector facadeVector = new Vector();
String text;
for (int i = 0; i < list.size(); i++) {
log.debug("QuestionPoolFacadeQueries: getAllItemFacadesOrderByItemText:: i = {}", i);
itemData = (ItemData) list.get(i);
itemFacade = new ItemFacade(itemData);
facadeVector.add(itemFacade);
log.debug("QuestionPoolFacadeQueries: getAllItemFacadesOrderByItemText:: getItemId = {}", itemData.getItemId());
log.debug("QuestionPoolFacadeQueries: getAllItemFacadesOrderByItemText:: getText = {}", itemData.getText());
// SAM-2499
text = formattedText.stripHtmlFromText(itemFacade.getText(), false, true);
log.debug("QuestionPoolFacadeQueries: getAllItemFacadesOrderByItemText:: getTextHtmlStrippedAll = '{}'", text);
origValueV = (Vector) hp.get(text);
if (origValueV == null) {
log.debug("QuestionPoolFacadeQueries: getAllItemFacadesOrderByItemText:: origValueV is null");
origValueV = new Vector();
}
origValueV.add(i);
hp.put(text, origValueV);
}
Vector v = new Vector(hp.keySet());
Collections.sort(v, String.CASE_INSENSITIVE_ORDER);
List itemList = new ArrayList();
Iterator it = v.iterator();
Vector orderdValueV;
Integer value;
String key;
if( (ascending!=null)&&("false").equals(ascending))
{//sort descending
for(int l=v.size()-1;l>=0;l--){
key = (String)v.get(l);
orderdValueV = (Vector) hp.get(key);
Iterator iter = orderdValueV.iterator();
while (iter.hasNext()) {
value = (Integer)iter.next();
ItemData itemdata = (ItemData) list.get(value);
ItemFacade f = new ItemFacade(itemdata);
itemList.add(f);
}
}
}
else{//sort ascending
while (it.hasNext()) {
key = (String)it.next();
orderdValueV = (Vector) hp.get(key);
Iterator iter = orderdValueV.iterator();
while (iter.hasNext()) {
value = (Integer)iter.next();
log.debug("QuestionPoolFacadeQueries: getAllItemFacadesOrderByItemText:: sorted (value) = {}", value);
itemFacade = (ItemFacade) facadeVector.get(value);
itemList.add(itemFacade);
}
}
}
return itemList;
}
public List getAllItemFacadesOrderByItemType(final Long questionPoolId,
final String orderBy, final String ascending) {
log.debug("QuestionPoolFacadeQueries: getAllItemFacadesOrderByItemType:: orderBy=" + orderBy);
final HibernateCallback hcb = session -> {
Query q;
if ("false".equals(ascending)) {
q = session.createQuery("select ab from ItemData ab, QuestionPoolItemData qpi, TypeD t where ab.itemId=qpi.itemId and ab.typeId=t.typeId and qpi.questionPoolId = :id order by t." +
orderBy + " desc");
} else {
q = session.createQuery("select ab from ItemData ab, QuestionPoolItemData qpi, TypeD t where ab.itemId=qpi.itemId and ab.typeId=t.typeId and qpi.questionPoolId = :id order by t." +
orderBy);
}
q.setParameter("id", questionPoolId);
log.debug("QuestionPoolFacadeQueries: getAllItemFacadesOrderByItemType:: getQueryString() = " + q.getQueryString());
return q.list();
};
List list = getHibernateTemplate().execute(hcb);
log.debug("QuestionPoolFacadeQueries: getAllItemFacadesOrderByItemType:: size = {}", list.size());
List itemList = new ArrayList();
for (int i = 0; i < list.size(); i++) {
ItemData itemdata = (ItemData) list.get(i);
ItemFacade f = new ItemFacade(itemdata);
itemList.add(f);
}
return itemList;
}
public List getAllItemFacades(final Long questionPoolId) {
final HibernateCallback hcb = session -> {
Query q = session.createQuery("select ab from ItemData ab, QuestionPoolItemData qpi where ab.itemId=qpi.itemId and qpi.questionPoolId = :id order by ab.itemId");
q.setParameter("id", questionPoolId.longValue());
return q.list();
};
List list = getHibernateTemplate().execute(hcb);
List itemList = new ArrayList();
for (int i = 0; i < list.size(); i++) {
ItemData itemdata = (ItemData) list.get(i);
ItemFacade f = new ItemFacade(itemdata);
itemList.add(f);
}
return itemList;
}
private void populateQuestionPoolItemDatas(QuestionPoolData qpp) {
try {
Set questionPoolItems = qpp.getQuestionPoolItems();
if (questionPoolItems != null) {
List itemList = getAllItems(qpp.getQuestionPoolId());
qpp.setQuestions(itemList);
qpp.setSubPoolSize(getSubPoolSize(qpp.getQuestionPoolId()));
}
}
catch (Exception e) {
log.error(e.getMessage(), e);
}
}
/**
* This method returns an ItemFacade that we can use to construct our ItemImpl
*/
public ItemFacade getItem(String id) {
ItemData item = (ItemData) getHibernateTemplate().load(ItemData.class, id);
return new ItemFacade(item);
}
/**
* Get a pool based on poolId. I am not sure why agent is not used though is being parsed.
*
* @param poolid DOCUMENTATION PENDING
* @param agent DOCUMENTATION PENDING
*
* @return DOCUMENTATION PENDING
*/
public QuestionPoolFacade getPool(Long poolId, String agent) {
try {
QuestionPoolData qpp = (QuestionPoolData) getHibernateTemplate().load(
QuestionPoolData.class, poolId);
// setAccessType
setPoolAccessType(qpp, agent);
// QuestionPoolItemData's identifier is a compsite identifier made up of
// poolId and itemId <-- is regarded as "legacy DB" in Hibernate language.
// We need to construct the properties for such as object ourselves.
populateQuestionPoolItemDatas(qpp);
return getQuestionPool(qpp);
}
catch (Exception e) {
log.error(e.getMessage(), e);
return null;
}
}
public void setPoolAccessType(QuestionPoolData qpp, String agentId) {
try {
QuestionPoolAccessData qpa = getQuestionPoolAccessData(qpp.
getQuestionPoolId(), agentId);
if (qpa == null) {
// if (qpa == null), take what is set for pool.
}
else {
qpp.setAccessTypeId(qpa.getAccessTypeId());
}
}
catch (Exception e) {
log.warn(e.getMessage());
}
}
public QuestionPoolAccessData getQuestionPoolAccessData(final Long poolId,
final String agentId) {
final HibernateCallback hcb = session -> {
Query q = session.createQuery("from QuestionPoolAccessData as qpa where qpa.questionPoolId = :id and qpa.agentId = :agent");
q.setParameter("id", poolId);
q.setParameter("agent", agentId);
return q.list();
};
List list = getHibernateTemplate().execute(hcb);
return (QuestionPoolAccessData) list.get(0);
}
/**
* DOCUMENTATION PENDING
*
* @param ids DOCUMENTATION PENDING
* @param sectionId DOCUMENTATION PENDING
*/
public void addItemsToSection(Collection ids, long sectionId) {
}
/**
* add a question to a pool
*
* @param itemId DOCUMENTATION PENDING
* @param poolId DOCUMENTATION PENDING
*/
public void addItemToPool(QuestionPoolItemData qpi) {
int retryCount = PersistenceService.getInstance().getPersistenceHelper().getRetryCount();
while (retryCount > 0){
try {
getHibernateTemplate().save(qpi);
retryCount = 0;
}
catch (Exception e) {
log.warn("problem saving item to pool: "+e.getMessage());
retryCount = PersistenceService.getInstance().getPersistenceHelper().retryDeadlock(e, retryCount);
}
}
}
/**
* Delete pool and questions attached to it plus any subpool under it
*
* @param itemId DOCUMENTATION PENDING
* @param poolId DOCUMENTATION PENDING
*/
public void deletePool(final Long poolId, final String agent, Tree tree) {
try {
QuestionPoolData questionPool = (QuestionPoolData) getHibernateTemplate().load(QuestionPoolData.class, poolId);
// #1. delete all questions which mean AssetBeanie (not ItemImpl) 'cos AssetBeanie
// is the one that is associated with the DB
// lydial: getting list of items that only belong to this pool and not linked to any assessments.
List itemList = getAllItemsInThisPoolOnlyAndDetachFromAssessment(poolId);
int retryCount = PersistenceService.getInstance().getPersistenceHelper().getRetryCount();
while (retryCount > 0){
try {
getHibernateTemplate().deleteAll(itemList); // delete all AssetBeanie
retryCount = 0;
}
catch (DataAccessException e) {
log.warn("problem delete all items in pool: "+e.getMessage());
retryCount = PersistenceService.getInstance().getPersistenceHelper().retryDeadlock(e, retryCount);
}
}
// #2. delete question and questionpool map.
retryCount = PersistenceService.getInstance().getPersistenceHelper().getRetryCount();
while (retryCount > 0){
try {
final HibernateCallback hcb = session -> {
Query q = session.createQuery("select qpi from QuestionPoolItemData as qpi where qpi.questionPoolId = :id");
q.setParameter("id", poolId);
return q.list();
};
List list = getHibernateTemplate().execute(hcb);
// a. delete item and pool association in SAM_ITEMMETADATA_T - this is the primary
// pool that item is attached to
List metaList = new ArrayList<>();
for (int j=0; j0){
ItemMetaDataIfc meta = (ItemMetaDataIfc)m.get(0);
meta.setEntry(null);
metaList.add(meta);
}
}
try{
for (ItemMetaDataIfc meta : metaList) {
getHibernateTemplate().saveOrUpdate(meta);
}
retryCount = 0;
}
catch (DataAccessException e) {
log.warn("problem delete question and questionpool map inside itemMetaData: {}", e.getMessage());
retryCount = PersistenceService.getInstance().getPersistenceHelper().retryDeadlock(e, retryCount);
}
// b. delete item and pool association in SAM_QUESTIONPOOLITEM_T
if (list.size() > 0) {
questionPool.setQuestionPoolItems(new HashSet());
getHibernateTemplate().deleteAll(list);
retryCount = 0;
}
else retryCount = 0;
}
catch (DataAccessException e) {
log.warn("problem delete question and questionpool map: "+e.getMessage());
retryCount = PersistenceService.getInstance().getPersistenceHelper().retryDeadlock(e, retryCount);
}
}
// #3. Pool is owned by one but can be shared by multiple agents. So need to
// delete all QuestionPoolAccessData record first. This seems to be missing in Navigo, nope? - daisyf
// Actually, I don't think we have ever implemented sharing between agents. So we may wnat to
// clean up this bit of code - daisyf 07/07/06
// #3a. Delete all shared pool by him sons
final HibernateCallback hcb = session -> {
Query q = session.createQuery("select qpa from QuestionPoolAccessData as qpa, QuestionPoolData as qpp " +
"where qpa.questionPoolId = qpp.questionPoolId and (qpp.questionPoolId = :qid or qpp.parentPoolId = :pid) ");
q.setParameter("qid", poolId);
q.setParameter("pid", poolId);
return q.list();
};
List qpaList = getHibernateTemplate().execute(hcb);
retryCount = PersistenceService.getInstance().getPersistenceHelper().getRetryCount();
while (retryCount > 0){
try {
getHibernateTemplate().deleteAll(qpaList);
retryCount = 0;
}
catch (DataAccessException e) {
log.warn("problem delete question pool access data: "+e.getMessage());
retryCount = PersistenceService.getInstance().getPersistenceHelper().retryDeadlock(e, retryCount);
}
}
// #4. Ready! delete pool now
final HibernateCallback hcb2 = session -> {
Query q = session.createQuery("select qp from QuestionPoolData as qp where qp.id = :id");
q.setParameter("id", poolId);
return q.list();
};
List qppList = getHibernateTemplate().execute(hcb2);
retryCount = PersistenceService.getInstance().getPersistenceHelper().getRetryCount();
while (retryCount > 0){
try {
getHibernateTemplate().deleteAll(qppList);
retryCount = 0;
}
catch (DataAccessException e) {
log.warn("problem delete all pools: "+e.getMessage());
retryCount = PersistenceService.getInstance().getPersistenceHelper().retryDeadlock(e, retryCount);
}
}
// #5. delete all subpools if any, this is recursive
if (tree != null) {
Iterator citer = (tree.getChildList(poolId)).iterator();
while (citer.hasNext()) {
deletePool( (Long) citer.next(), agent, tree);
}
}
}
catch (DataAccessException e) {
log.warn("error deleting pool. " + e.getMessage());
}
}
/**
* Move pool under another pool. The dest pool must not be the
* descendant of the source nor can they be the same pool .
*/
public void movePool(String agentId, Long sourcePoolId, Long destPoolId) {
try {
QuestionPoolFacade sourcePool = getPool(sourcePoolId, agentId);
if (destPoolId.equals(QuestionPoolFacade.ROOT_POOL) &&
!sourcePoolId.equals(QuestionPoolFacade.ROOT_POOL)) {
sourcePool.setParentPoolId(QuestionPoolFacade.ROOT_POOL);
int retryCount = PersistenceService.getInstance().getPersistenceHelper().getRetryCount();
while (retryCount > 0){
try {
getHibernateTemplate().update( (QuestionPoolData) sourcePool.getData());
retryCount = 0;
}
catch (DataAccessException e) {
log.warn("problem moving pool: "+e.getMessage());
retryCount = PersistenceService.getInstance().getPersistenceHelper().retryDeadlock(e, retryCount);
}
}
}
else {
QuestionPoolFacade destPool = getPool(destPoolId, agentId);
sourcePool.setParentPoolId(destPool.getQuestionPoolId());
int retryCount = PersistenceService.getInstance().getPersistenceHelper().getRetryCount();
while (retryCount > 0){
try {
getHibernateTemplate().update( (QuestionPoolData) sourcePool.getData());
retryCount = 0;
}
catch (DataAccessException e) {
log.warn("problem update source pool: "+e.getMessage());
retryCount = PersistenceService.getInstance().getPersistenceHelper().retryDeadlock(e, retryCount);
}
}
}
}
catch (RuntimeException e) {
log.warn(e.getMessage());
}
}
/**
* Is destination a descendant of the source?
*/
public boolean isDescendantOf(QuestionPoolFacade destPool,
QuestionPoolFacade sourcePool) {
Long tempPoolId = destPool.getQuestionPoolId();
try {
while((tempPoolId != null) &&
(!tempPoolId.equals(QuestionPoolFacade.ROOT_POOL)))
{
QuestionPoolFacade tempPool = getPoolById(tempPoolId);
if (tempPool.getParentPoolId().equals(sourcePool.getQuestionPoolId())) {
return true;
}
tempPoolId = tempPool.getParentPoolId();
}
return false;
}
catch (Exception e) {
log.warn(e.getMessage());
return false;
}
}
/**
* DOCUMENTATION PENDING
*
* @param itemId DOCUMENTATION PENDING
* @param poolId DOCUMENTATION PENDING
*/
public void removeItemFromPool(Long itemId, Long poolId) {
QuestionPoolItemData qpi = new QuestionPoolItemData(poolId, itemId);
int retryCount = PersistenceService.getInstance().getPersistenceHelper().getRetryCount();
while (retryCount > 0){
try {
getHibernateTemplate().delete(getHibernateTemplate().merge(qpi));
retryCount = 0;
}
catch (Exception e) {
log.warn("problem delete item from pool: "+e.getMessage());
retryCount = PersistenceService.getInstance().getPersistenceHelper().retryDeadlock(e, retryCount);
}
}
}
/**
* DOCUMENTATION PENDING
*
* @param itemId DOCUMENTATION PENDING
* @param poolId DOCUMENTATION PENDING
*/
public void moveItemToPool(Long itemId, Long sourceId, Long destId) {
QuestionPoolItemData qpi = new QuestionPoolItemData(sourceId, itemId);
int retryCount = PersistenceService.getInstance().getPersistenceHelper().getRetryCount();
while (retryCount > 0){
try {
getHibernateTemplate().delete(getHibernateTemplate().merge(qpi));
retryCount = 0;
}
catch (Exception e) {
log.warn("problem delete old mapping: "+e.getMessage());
retryCount = PersistenceService.getInstance().getPersistenceHelper().retryDeadlock(e, retryCount);
}
}
QuestionPoolItemData qpi2 = new QuestionPoolItemData(destId, itemId);
retryCount = PersistenceService.getInstance().getPersistenceHelper().getRetryCount();
while (retryCount > 0){
try {
getHibernateTemplate().save(qpi2);
retryCount = 0;
}
catch (Exception e) {
log.warn("problem saving new mapping: "+e.getMessage());
retryCount = PersistenceService.getInstance().getPersistenceHelper().retryDeadlock(e, retryCount);
}
}
}
/**
* DOCUMENTATION PENDING
*
* @param pool DOCUMENTATION PENDING
*/
public QuestionPoolFacade savePool(QuestionPoolFacade pool) {
boolean insert = false;
try {
QuestionPoolData qpp = (QuestionPoolData) pool.getData();
qpp.setLastModified(new Date());
qpp.setLastModifiedById(AgentFacade.getAgentString());
int retryCount = PersistenceService.getInstance().getPersistenceHelper().getRetryCount();
if (qpp.getQuestionPoolId() == null ||
qpp.getQuestionPoolId().equals(new Long("0"))) { // indicate a new pool
insert = true;
}
while (retryCount > 0){
try {
getHibernateTemplate().saveOrUpdate(qpp);
retryCount = 0;
}
catch (DataAccessException e) {
log.warn("problem saving Or Update pool: "+e.getMessage());
retryCount = PersistenceService.getInstance().getPersistenceHelper().retryDeadlock(e, retryCount);
}
}
if (insert) {
// add a QuestionPoolAccessData record for the owner who should have ADMIN access to the pool
QuestionPoolAccessData qpa = new QuestionPoolAccessData(qpp.
getQuestionPoolId(), qpp.getOwnerId(), QuestionPoolData.ADMIN);
retryCount = PersistenceService.getInstance().getPersistenceHelper().getRetryCount();
while (retryCount > 0){
try {
getHibernateTemplate().save(qpa);
retryCount = 0;
}
catch (DataAccessException e) {
log.warn("problem saving pool: "+e.getMessage());
retryCount = PersistenceService.getInstance().getPersistenceHelper().retryDeadlock(e, retryCount);
}
}
// add a QuestionPoolAccessData record for all users who are sharing the subpool
final long parentPoolId = qpp.getParentPoolId();
final String ownerId = qpp.getOwnerId();
if (parentPoolId != 0) {
List listSubpool = new ArrayList();
try {
listSubpool = (List) getHibernateTemplate()
.findByNamedParam("from QuestionPoolAccessData as qpa where qpa.questionPoolId = :id and qpa.agentId <> :agent",
new String[] {"id", "agent"},
new Object[] { Long.valueOf(parentPoolId), ownerId});
} catch (Exception e1) {
log.warn("problem finding pool: "+e1.getMessage());
}
for (QuestionPoolAccessData questioPoolData : listSubpool) {
qpa = new
QuestionPoolAccessData(qpp.getQuestionPoolId(),
questioPoolData.getAgentId(), QuestionPoolData.READ_COPY);
retryCount =
PersistenceService.getInstance().getPersistenceHelper().getRetryCount();
while (retryCount > 0){
try {
getHibernateTemplate().save(qpa);
retryCount = 0;
}
catch (DataAccessException e) {
log.warn("problem saving pool: "+e.getMessage());
retryCount =
PersistenceService.getInstance().getPersistenceHelper().retryDeadlock(e, retryCount);
}
}
}
}
}
return pool;
}
catch (RuntimeException e) {
log.warn(e.getMessage());
return null;
}
}
/**
* Get all the children pools of a pool. Return a list of QuestionPoolData
* should return QuestionPool instead - need fixing, daisyf
*
* @param itemId DOCUMENTATION PENDING
* @param poolId DOCUMENTATION PENDING
*/
public List getSubPools(final Long poolId) {
final HibernateCallback hcb = session -> {
Query q = session.createQuery("from QuestionPoolData as qpp where qpp.parentPoolId = :id");
q.setParameter("id", poolId.longValue());
return q.list();
};
return getHibernateTemplate().execute(hcb);
}
@Override
public List getSubPoolSizes(final String agent) {
final HibernateCallback> hcb = session -> {
Query q = session.createQuery("select a.questionPoolId, (select count(*) from QuestionPoolData b where b.parentPoolId=a.questionPoolId) " +
"from QuestionPoolData a where a.ownerId = :id");
q.setCacheable(true);
q.setParameter("id", agent);
return q.list();
};
List
© 2015 - 2025 Weber Informatics LLC | Privacy Policy