/** * “Copyright 2012 Megam Systems” * This program is free software: you can redistribute it and/or modify * it under the terms of the GNU General Public License as published by * the Free Software Foundation, either version 3 of the License, or * (at your option) any later version. * * This program is distributed in the hope that it will be useful, * but WITHOUT ANY WARRANTY; without even the implied warranty of * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the * GNU General Public License for more details. * * You should have received a copy of the GNU General Public License * along with this program. If not, see <http://www.gnu.org/licenses/>. **/ package org.megam.deccanplato.provider.salesforce.chatter.handler; import java.io.IOException; import java.net.URISyntaxException; import java.util.HashMap; import java.util.Map; import static org.megam.deccanplato.provider.salesforce.chatter.Constants.*; import static org.megam.deccanplato.provider.Constants.*; import org.apache.http.client.ClientProtocolException; import org.apache.http.entity.ContentType; import org.megam.deccanplato.http.TransportMachinery; import org.megam.deccanplato.http.TransportResponse; import org.megam.deccanplato.http.TransportTools; import org.megam.deccanplato.provider.BusinessActivity; import org.megam.deccanplato.provider.core.BusinessActivityInfo; import org.megam.deccanplato.provider.salesforce.chatter.info.Post; import com.google.gson.Gson; import com.google.gson.GsonBuilder; /** * @author pandiyaraja * * This class deals with salesforce chatter functionality of * feed resources. It shows likes, comments and list of user feeds. * */ public class FeedImpl implements BusinessActivity { private BusinessActivityInfo bizInfo; private Map<String, String> args = new HashMap<String, String>(); /* * (non-Javadoc) * * @see * org.megam.deccanplato.provider.BusinessActivity#setArguments(org.megam * .deccanplato.provider.core.BusinessActivityInfo, java.util.Map) */ @Override public void setArguments(BusinessActivityInfo tempBizInfo, Map<String, String> tempArgs) { this.bizInfo = tempBizInfo; this.args = tempArgs; } /* * (non-Javadoc) * * @see org.megam.deccanplato.provider.BusinessActivity#run() */ @Override public Map<String, String> run() { Map<String, String> outMap = null; switch (bizInfo.getActivityFunction()) { case LIST: outMap = list(); break; case DELETE: outMap=delete(); break; case COMMENT: outMap=comment(); break; case LIKE: outMap=like(); break; case FEED: outMap=feed(); break; case POSTCOMMENT: outMap=postcomment(); break; } return outMap; } /** * Comment post not working * @param outMap * @return */ private Map<String, String> postcomment() { Map<String, String> outMap=new HashMap<>(); final String SALESFORCE_CHATTER_URL = args.get(INSTANCE_URL)+"/services/data/v25.0/chatter/feed-items/"+args.get(ID)+"/comments?"; Map<String,String> header=new HashMap<String,String>(); header.put(S_AUTHORIZATION, S_OAUTH+args.get(ACCESS_TOKEN)); Gson gson=new Gson(); Map<String, Object> accountAttrMap = new HashMap<String, Object>(); accountAttrMap.put(S_TEXT, gson.toJson(new Post(args.get(TYPE), args.get(TEXT)))); TransportTools tst=new TransportTools(SALESFORCE_CHATTER_URL, null, header); Gson obj = new GsonBuilder().setPrettyPrinting().create(); tst.setContentType(ContentType.APPLICATION_JSON, obj.toJson(accountAttrMap)); try { String response=TransportMachinery.post(tst).entityToString(); outMap.put(OUTPUT, response); } catch (ClientProtocolException e) { e.printStackTrace(); } catch (IOException e) { e.printStackTrace(); } return outMap; } /** * This method shows news feeds * @param outMap * @return */ private Map<String, String> feed() { Map<String, String> outMap=new HashMap<>(); final String SALESFORCE_CHATTER_ANSWER_ACTIVITY_URL = "/services/data/v25.0/chatter/feeds/news/"+args.get(ID)+"/feed-items"; Map<String, String> header = new HashMap<String, String>(); header.put(S_AUTHORIZATION, S_OAUTH + args.get(ACCESS_TOKEN)); TransportTools tst = new TransportTools(args.get(INSTANCE_URL) + SALESFORCE_CHATTER_ANSWER_ACTIVITY_URL, null, header); try { String response = TransportMachinery.get(tst).entityToString(); outMap.put(OUTPUT, response); } catch (ClientProtocolException e) { e.printStackTrace(); } catch (IOException e) { e.printStackTrace(); } catch (URISyntaxException e) { e.printStackTrace(); } return outMap; } /** * this method shows list of likes of a users comment or post * it takes in put as * @param outMap * @return */ private Map<String, String> like() { Map<String, String> outMap=new HashMap<>(); final String SALESFORCE_CHATTER_ACTIVITY_URL = "/services/data/v25.0/chatter/feed-items/"+args.get(ID)+"/likes"; Map<String, String> header = new HashMap<String, String>(); header.put(S_AUTHORIZATION, S_OAUTH + args.get(ACCESS_TOKEN)); TransportTools tst = new TransportTools(args.get(INSTANCE_URL)+SALESFORCE_CHATTER_ACTIVITY_URL, null, header); try { String response = TransportMachinery.get(tst).entityToString(); outMap.put(OUTPUT, response); } catch (ClientProtocolException e) { e.printStackTrace(); } catch (IOException e) { e.printStackTrace(); } catch (URISyntaxException e) { e.printStackTrace(); } return outMap; } /** * This method shows the comment item details and comment id * it also shows comment count. * @param outMap feed item id * @return */ private Map<String, String> comment() { Map<String, String> outMap=new HashMap<>(); final String SALESFORCE_CHATTER_ACTIVITY_URL = "/services/data/v25.0/chatter/feed-items/"+args.get(ID)+"/comments"; Map<String, String> header = new HashMap<String, String>(); header.put(S_AUTHORIZATION, S_OAUTH + args.get(ACCESS_TOKEN)); TransportTools tst = new TransportTools(args.get(INSTANCE_URL)+SALESFORCE_CHATTER_ACTIVITY_URL, null, header); try { String response = TransportMachinery.get(tst).entityToString(); outMap.put(OUTPUT, response); } catch (ClientProtocolException e) { e.printStackTrace(); } catch (IOException e) { e.printStackTrace(); } catch (URISyntaxException e) { e.printStackTrace(); } return outMap; } /** * this method deletes a feed item form user feed * it takes input as feed id * @param outMap * @return */ private Map<String, String> delete() { Map<String, String> outMap=new HashMap<>(); final String SALESFORCE_CHATTER_ACTIVITY_URL = "/services/data/v25.0/chatter/feed-items/"+args.get(ID); Map<String, String> header = new HashMap<String, String>(); header.put(S_AUTHORIZATION, S_OAUTH + args.get(ACCESS_TOKEN)); TransportTools tst = new TransportTools(args.get(INSTANCE_URL)+SALESFORCE_CHATTER_ACTIVITY_URL, null, header); try { String response = TransportMachinery.delete(tst).entityToString(); outMap.put(OUTPUT, response); } catch (ClientProtocolException e) { e.printStackTrace(); } catch (IOException e) { e.printStackTrace(); } return outMap; } /** * This method shows list of feed items and access that items * It takes feed id as input. * @param outMap * @return list of user feeds. */ private Map<String, String> list() { Map<String, String> outMap=new HashMap<>(); final String SALESFORCE_CHATTER_ACTIVITY_URL = "/services/data/v25.0/chatter/feed-items/"+args.get(ID); Map<String, String> header = new HashMap<String, String>(); header.put(S_AUTHORIZATION, S_OAUTH + args.get(ACCESS_TOKEN)); TransportTools tst = new TransportTools(args.get(INSTANCE_URL)+SALESFORCE_CHATTER_ACTIVITY_URL, null, header); try { String response = TransportMachinery.get(tst).entityToString(); outMap.put(OUTPUT, response); } catch (ClientProtocolException e) { e.printStackTrace(); } catch (IOException e) { e.printStackTrace(); } catch (URISyntaxException e) { e.printStackTrace(); } return outMap; } /* * (non-Javadoc) * * @see org.megam.deccanplato.provider.BusinessActivity#name() */ @Override public String name() { return "feed"; } }