mirror of
https://github.com/Alfresco/alfresco-community-repo.git
synced 2025-08-14 17:58:59 +00:00
User status changes now generate activities
Activities Dashlet: - added "I'm following" filter - prepared activities filter (not working yet) git-svn-id: https://svn.alfresco.com/repos/alfresco-enterprise/alfresco/HEAD/root@28589 c4b6b30b-aa2e-2d43-bbcb-ca4b014f7261
This commit is contained in:
@@ -7,9 +7,9 @@
|
||||
<url>/api/activities/feed/user?s={siteId?}</url>
|
||||
<url>/api/activities/feed/user?s={siteId?}&format=atomfeed</url>
|
||||
<url>/api/activities/feed/user?s={siteId?}&format=json</url>
|
||||
<url>/api/activities/feed/user?s={siteId?}&exclUser={false?}&exclOthers={false?}</url>
|
||||
<url>/api/activities/feed/user?s={siteId?}&exclUser={false?}&exclOthers={false?}&format=atomfeed</url>
|
||||
<url>/api/activities/feed/user?s={siteId?}&exclUser={false?}&exclOthers={false?}&format=json</url>
|
||||
<url>/api/activities/feed/user?s={siteId?}&exclUser={false?}&exclOthers={false?}&following={false?}&activityFilter={activityFilter}</url>
|
||||
<url>/api/activities/feed/user?s={siteId?}&exclUser={false?}&exclOthers={false?}&following={false?}&activityFilter={activityFilter}&format=atomfeed</url>
|
||||
<url>/api/activities/feed/user?s={siteId?}&exclUser={false?}&exclOthers={false?}&following={false?}&activityFilter={activityFilter}&format=json</url>
|
||||
<format default="atomfeed"></format>
|
||||
<authentication>user</authentication>
|
||||
<transaction allow="readonly">required</transaction>
|
||||
|
@@ -25,6 +25,10 @@ function main()
|
||||
model.success = true;
|
||||
model.userStatus = newStatus;
|
||||
model.userStatusTime = statusTime;
|
||||
|
||||
var activity = {};
|
||||
activity.status = newStatus;
|
||||
activities.postActivity("org.alfresco.profile.status-changed", null, "profile", jsonUtils.toJSONString(activity));
|
||||
}
|
||||
}
|
||||
}
|
||||
|
@@ -549,13 +549,13 @@
|
||||
<!-- Activity User Feed - to get activities feed for logged in user -->
|
||||
<bean id="webscript.org.alfresco.repository.activities.feed.userfeed.get" class="org.alfresco.repo.web.scripts.activities.feed.UserFeedRetrieverWebScript" parent="webscript">
|
||||
<property name="activityService" ref="activityService"/>
|
||||
<property name="authorityService" ref="AuthorityService"/>
|
||||
<property name="subscriptionService" ref="SubscriptionService"/>
|
||||
</bean>
|
||||
|
||||
<!-- Activity Admin Feed - to get activities feed for specified user -->
|
||||
<bean id="webscript.org.alfresco.repository.activities.feed.userfeed-admin.get" class="org.alfresco.repo.web.scripts.activities.feed.UserFeedRetrieverWebScript" parent="webscript">
|
||||
<property name="activityService" ref="activityService"/>
|
||||
<property name="authorityService" ref="AuthorityService"/>
|
||||
<property name="subscriptionService" ref="SubscriptionService"/>
|
||||
</bean>
|
||||
|
||||
<!-- Activity Site Feed - to get activities feed for given site, if private site then need to be a member or admin -->
|
||||
|
@@ -20,22 +20,26 @@ package org.alfresco.repo.web.scripts.activities.feed;
|
||||
|
||||
import java.util.ArrayList;
|
||||
import java.util.HashMap;
|
||||
import java.util.HashSet;
|
||||
import java.util.List;
|
||||
import java.util.Map;
|
||||
import java.util.Set;
|
||||
|
||||
import org.alfresco.error.AlfrescoRuntimeException;
|
||||
import org.alfresco.query.PagingRequest;
|
||||
import org.alfresco.repo.activities.feed.FeedTaskProcessor;
|
||||
import org.alfresco.repo.security.authentication.AuthenticationUtil;
|
||||
import org.alfresco.repo.security.permissions.AccessDeniedException;
|
||||
import org.alfresco.service.cmr.activities.ActivityService;
|
||||
import org.alfresco.service.cmr.security.AuthorityService;
|
||||
import org.alfresco.service.cmr.subscriptions.PagingFollowingResults;
|
||||
import org.alfresco.service.cmr.subscriptions.SubscriptionService;
|
||||
import org.alfresco.util.JSONtoFmModel;
|
||||
import org.springframework.extensions.webscripts.DeclarativeWebScript;
|
||||
import org.springframework.extensions.webscripts.Status;
|
||||
import org.springframework.extensions.webscripts.WebScriptRequest;
|
||||
import org.apache.commons.logging.Log;
|
||||
import org.apache.commons.logging.LogFactory;
|
||||
import org.json.JSONException;
|
||||
import org.springframework.extensions.webscripts.DeclarativeWebScript;
|
||||
import org.springframework.extensions.webscripts.Status;
|
||||
import org.springframework.extensions.webscripts.WebScriptRequest;
|
||||
|
||||
/**
|
||||
* Java-backed WebScript to retrieve Activity User Feed
|
||||
@@ -48,21 +52,22 @@ public class UserFeedRetrieverWebScript extends DeclarativeWebScript
|
||||
public static final String PARAM_SITE_ID = "s";
|
||||
public static final String PARAM_EXCLUDE_THIS_USER = "exclUser";
|
||||
public static final String PARAM_EXCLUDE_OTHER_USERS = "exclOthers";
|
||||
public static final String PARAM_ONLY_FOLLOWING = "following";
|
||||
public static final String PARAM_ACTIVITY_FILTER = "activityFilter";
|
||||
|
||||
private ActivityService activityService;
|
||||
private AuthorityService authorityService;
|
||||
private SubscriptionService subscriptionService;
|
||||
|
||||
public void setActivityService(ActivityService activityService)
|
||||
{
|
||||
this.activityService = activityService;
|
||||
}
|
||||
|
||||
public void setAuthorityService(AuthorityService authorityService)
|
||||
public void setSubscriptionService(SubscriptionService subscriptionService)
|
||||
{
|
||||
this.authorityService = authorityService;
|
||||
this.subscriptionService = subscriptionService;
|
||||
}
|
||||
|
||||
|
||||
/* (non-Javadoc)
|
||||
* @see org.alfresco.web.scripts.DeclarativeWebScript#executeImpl(org.alfresco.web.scripts.WebScriptRequest, org.alfresco.web.scripts.WebScriptResponse)
|
||||
*/
|
||||
@@ -94,6 +99,8 @@ public class UserFeedRetrieverWebScript extends DeclarativeWebScript
|
||||
String siteId = req.getParameter(PARAM_SITE_ID); // optional
|
||||
String exclThisUserStr = req.getParameter(PARAM_EXCLUDE_THIS_USER); // optional
|
||||
String exclOtherUsersStr = req.getParameter(PARAM_EXCLUDE_OTHER_USERS); // optional
|
||||
String onlyFollowingStr = req.getParameter(PARAM_ONLY_FOLLOWING); // optional
|
||||
String activityFilterStr = req.getParameter(PARAM_ACTIVITY_FILTER); // optional
|
||||
|
||||
boolean exclThisUser = false;
|
||||
if ((exclThisUserStr != null) && (exclThisUserStr.equalsIgnoreCase("true") || exclThisUserStr.equalsIgnoreCase("t")))
|
||||
@@ -107,6 +114,28 @@ public class UserFeedRetrieverWebScript extends DeclarativeWebScript
|
||||
exclOtherUsers = true;
|
||||
}
|
||||
|
||||
Set<String> userFilter = null;
|
||||
if ((onlyFollowingStr != null) && (onlyFollowingStr.equalsIgnoreCase("true") || onlyFollowingStr.equalsIgnoreCase("t")))
|
||||
{
|
||||
PagingFollowingResults following = subscriptionService.getFollowers(AuthenticationUtil.getRunAsUser(), new PagingRequest(-1, null));
|
||||
if (following.getPage() != null)
|
||||
{
|
||||
userFilter = new HashSet<String>();
|
||||
userFilter.addAll(following.getPage());
|
||||
}
|
||||
}
|
||||
|
||||
Set<String> activityFilter = null;
|
||||
if (activityFilterStr != null)
|
||||
{
|
||||
activityFilter = new HashSet<String>();
|
||||
String[] activities = activityFilterStr.split(",");
|
||||
for (String s : activities)
|
||||
{
|
||||
activityFilter.add(s);
|
||||
}
|
||||
}
|
||||
|
||||
if ((feedUserId == null) || (feedUserId.length() == 0))
|
||||
{
|
||||
feedUserId = AuthenticationUtil.getFullyAuthenticatedUser();
|
||||
|
Reference in New Issue
Block a user