From f56f887181d11f180eedc07ba95c20dc55716c19 Mon Sep 17 00:00:00 2001 From: Gundala Date: Tue, 6 Jan 2015 11:17:18 -0500 Subject: [PATCH] SAK-28088 --- .../entity/DecoratedForumInfo.java | 12 +++++- .../entity/DecoratedTopicInfo.java | 12 +++++- .../entity/TopicEntityProviderImpl.java | 37 ++++++++++++++++++- 3 files changed, 57 insertions(+), 4 deletions(-) diff --git a/msgcntr/messageforums-api/src/java/org/sakaiproject/api/app/messageforums/entity/DecoratedForumInfo.java b/msgcntr/messageforums-api/src/java/org/sakaiproject/api/app/messageforums/entity/DecoratedForumInfo.java index d7e39f41f449..16d4e50325b1 100644 --- a/msgcntr/messageforums-api/src/java/org/sakaiproject/api/app/messageforums/entity/DecoratedForumInfo.java +++ b/msgcntr/messageforums-api/src/java/org/sakaiproject/api/app/messageforums/entity/DecoratedForumInfo.java @@ -17,6 +17,7 @@ public class DecoratedForumInfo { private Long openDate; // An epoch date in seconds. NOT milliseconds. private Long closeDate; // An epoch date in seconds. NOT milliseconds. private String gradebookItemName; + private Long gradebookItemId; public DecoratedForumInfo(Long forumId, String forumTitle, List attachments, String shortDescription, @@ -32,7 +33,7 @@ public DecoratedForumInfo(Long forumId, String forumTitle, List attachments, String shortDescription, String description, Boolean isLocked, Boolean isPostFirst, Boolean isAvailabilityRestricted, Long openDate, Long closeDate, - String gradebookItemName) { + String gradebookItemName, Long gradebookItemId) { this(forumId, forumTitle, attachments, shortDescription, description); this.isLocked = isLocked; this.isPostFirst = isPostFirst; @@ -40,6 +41,7 @@ public DecoratedForumInfo(Long forumId, String forumTitle, this.openDate = openDate; this.closeDate = closeDate; this.gradebookItemName = gradebookItemName; + this.gradebookItemId = gradebookItemId; } public Long getForumId() { @@ -117,6 +119,14 @@ public String getGradebookItemName() { public void setGradebookItemName(String gradebookItemName) { this.gradebookItemName = gradebookItemName; } + + public Long getGradebookItemId() { + return gradebookItemId; + } + + public void setGradebookItemId(Long gradebookItemId) { + this.gradebookItemId = gradebookItemId; + } public String getShortDescription() { return shortDescription; diff --git a/msgcntr/messageforums-api/src/java/org/sakaiproject/api/app/messageforums/entity/DecoratedTopicInfo.java b/msgcntr/messageforums-api/src/java/org/sakaiproject/api/app/messageforums/entity/DecoratedTopicInfo.java index 972c309817e9..727207088638 100644 --- a/msgcntr/messageforums-api/src/java/org/sakaiproject/api/app/messageforums/entity/DecoratedTopicInfo.java +++ b/msgcntr/messageforums-api/src/java/org/sakaiproject/api/app/messageforums/entity/DecoratedTopicInfo.java @@ -18,6 +18,7 @@ public class DecoratedTopicInfo { private Long openDate; // An epoch date in seconds. NOT milliseconds. private Long closeDate; // An epoch date in seconds. NOT milliseconds. private String gradebookItemName; + private Long gradebookItemId; public DecoratedTopicInfo(Long topicId, String topicTitle, int unreadMessagesCount, int messagesCount, String typeUuid, @@ -39,7 +40,7 @@ public DecoratedTopicInfo(Long topicId, String topicTitle, List attachments, String shortDescription, String description, Boolean isLocked, Boolean isPostFirst, Boolean isAvailabilityRestricted, Long openDate, Long closeDate, - String gradebookItemName) { + String gradebookItemName, Long gradebookItemId) { this(topicId, topicTitle, unreadMessagesCount, messagesCount, typeUuid, attachments, shortDescription, description); @@ -49,6 +50,7 @@ public DecoratedTopicInfo(Long topicId, String topicTitle, this.openDate = openDate; this.closeDate = closeDate; this.gradebookItemName = gradebookItemName; + this.gradebookItemId = gradebookItemId; } public String getTypeUuid() { @@ -139,6 +141,14 @@ public void setGradebookItemName(String gradebookItemName) { this.gradebookItemName = gradebookItemName; } + public Long getGradebookItemId() { + return gradebookItemId; + } + + public void setGradebookItemId(Long gradebookItemId) { + this.gradebookItemId = gradebookItemId; + } + public List getAttachments() { return attachments; } diff --git a/msgcntr/messageforums-component-impl/src/java/org/sakaiproject/component/app/messageforums/entity/TopicEntityProviderImpl.java b/msgcntr/messageforums-component-impl/src/java/org/sakaiproject/component/app/messageforums/entity/TopicEntityProviderImpl.java index 5a29bcf57d0a..980d86c44f43 100644 --- a/msgcntr/messageforums-component-impl/src/java/org/sakaiproject/component/app/messageforums/entity/TopicEntityProviderImpl.java +++ b/msgcntr/messageforums-component-impl/src/java/org/sakaiproject/component/app/messageforums/entity/TopicEntityProviderImpl.java @@ -29,6 +29,7 @@ import org.sakaiproject.api.app.messageforums.ui.PrivateMessageManager; import org.sakaiproject.api.app.messageforums.ui.UIPermissionsManager; import org.sakaiproject.component.app.messageforums.dao.hibernate.PrivateTopicImpl; +import org.sakaiproject.component.cover.ComponentManager; import org.sakaiproject.component.cover.ServerConfigurationService; import org.sakaiproject.entity.api.Reference; import org.sakaiproject.entity.cover.EntityManager; @@ -48,6 +49,9 @@ import org.sakaiproject.entitybroker.entityprovider.extension.RequestStorage; import org.sakaiproject.entitybroker.entityprovider.search.Restriction; import org.sakaiproject.entitybroker.entityprovider.search.Search; +import org.sakaiproject.service.gradebook.shared.Assignment; +import org.sakaiproject.service.gradebook.shared.GradebookNotFoundException; +import org.sakaiproject.service.gradebook.shared.GradebookService; import org.sakaiproject.user.cover.UserDirectoryService; import org.sakaiproject.util.ResourceLoader; @@ -353,6 +357,22 @@ public List getEntities(EntityReference ref, Search search) { }else{ forums = forumManager.getDiscussionForumsWithTopics(siteId); } + + // retrieve all of the gradebook items here so we aren't checking repeatedly + Map gbItemNameToId = new HashMap(); + try { + GradebookService gradebookService = (GradebookService)ComponentManager.get("org.sakaiproject.service.gradebook.GradebookService"); + List gbItems = gradebookService.getAssignments(siteId); + if (gbItems != null) { + for (Assignment gbItem : gbItems) { + gbItemNameToId.put(gbItem.getName(), gbItem.getId()); + } + } + } catch (GradebookNotFoundException gnfe) { + LOG.debug("No gradebook exists for site " + siteId + ". No gb item ids will be included.", gnfe); + } catch (Exception e) { + LOG.debug("Exception attempting to retrieve gradebook information for site " + siteId + ". ", e); + } for (DiscussionForum forum : forums) { if(forum.getDraft().equals(Boolean.FALSE)){ @@ -363,9 +383,15 @@ public List getEntities(EntityReference ref, Search search) { forumOpenDate = forum.getOpenDate() != null ? forum.getOpenDate().getTime()/1000 : null; forumCloseDate = forum.getCloseDate() != null ? forum.getCloseDate().getTime()/1000 : null; } + + Long forumGbItemId = null; + if (forum.getDefaultAssignName() != null && !forum.getDefaultAssignName().isEmpty() && + gbItemNameToId.containsKey(forum.getDefaultAssignName())) { + forumGbItemId = gbItemNameToId.get(forum.getDefaultAssignName()); + } DecoratedForumInfo dForum = new DecoratedForumInfo(forum.getId(), forum.getTitle(), forumAttachments, forum.getShortDescription(), forum.getExtendedDescription(), forum.getLocked(), - forum.getPostFirst(), forum.getAvailabilityRestricted(), forumOpenDate, forumCloseDate, forum.getDefaultAssignName()); + forum.getPostFirst(), forum.getAvailabilityRestricted(), forumOpenDate, forumCloseDate, forum.getDefaultAssignName(), forumGbItemId); List topics = forum.getTopics(); int viewableTopics = 0; @@ -398,9 +424,16 @@ public List getEntities(EntityReference ref, Search search) { topicOpenDate = topic.getOpenDate() != null ? topic.getOpenDate().getTime()/1000 : null; topicCloseDate = topic.getCloseDate() != null ? topic.getCloseDate().getTime()/1000 : null; } + + Long topicGbItemId = null; + if (topic.getDefaultAssignName() != null && !topic.getDefaultAssignName().isEmpty() && + gbItemNameToId.containsKey(topic.getDefaultAssignName())) { + topicGbItemId = gbItemNameToId.get(topic.getDefaultAssignName()); + } + dForum.addTopic(new DecoratedTopicInfo(topic.getId(), topic.getTitle(), unreadMessages, totalMessages, "", attachments, topic.getShortDescription(), topic.getExtendedDescription(), topic.getLocked(), topic.getPostFirst(), topic.getAvailabilityRestricted(), - topicOpenDate, topicCloseDate, topic.getDefaultAssignName())); + topicOpenDate, topicCloseDate, topic.getDefaultAssignName(), topicGbItemId)); viewableTopics++; } }