
prerna.reactor.task.lambda.flatmap.TwitterSearchLambda Maven / Gradle / Ivy
The newest version!
package prerna.reactor.task.lambda.flatmap;
import java.util.HashMap;
import java.util.List;
import java.util.Map;
import java.util.Vector;
import org.apache.logging.log4j.LogManager;
import org.apache.logging.log4j.Logger;
import prerna.engine.api.IHeadersDataRow;
import prerna.io.connector.twitter.TwitterSearcher;
import prerna.om.Viewpoint;
import prerna.util.Constants;
public class TwitterSearchLambda extends AbstractFlatMapLambda {
private static final Logger classLogger = LogManager.getLogger(TwitterSearchLambda.class);
// col index we care about to get lat/long from
private int colIndex;
// total number of columns
private int totalCols;
@Override
public List process(IHeadersDataRow row) {
Object value = row.getValues()[colIndex];
if(value == null || value.toString().isEmpty()) {
return new Vector();
}
// construct new values to append onto the row
// add new headers
String[] newHeaders = new String[]{"review", "author", "retweet_count"};
Map params = new HashMap<>();
params.put("q", value.toString().replace("_", " "));
params.put("lang", "en");
if(this.params.containsKey("output"))
params.put("count", this.params.get("output"));
else
params.put("count", "10");
if(this.params.containsKey("result_type"))
params.put("result_type", this.params.get("result_type"));
else
params.put("result_type", "mixed");
List retList = new Vector();
// add new values
try {
// loop through the results
TwitterSearcher ts = new TwitterSearcher();
Object resultObj = ts.execute(this.user, params);
if(resultObj instanceof List) {
List results = (List) resultObj;
for(int i = 0; i < results.size(); i++) {
Viewpoint view = results.get(i);
processView(view, newHeaders, row, retList);
}
} else {
Viewpoint view = (Viewpoint) resultObj;
processView(view, newHeaders, row, retList);
}
} catch(Exception e) {
classLogger.error(Constants.STACKTRACE, e);
}
return retList;
}
/**
* Process a view point
* @param view
* @param newHeaders
* @param curRow
* @param retList
*/
private void processView(Viewpoint view, String[] newHeaders, IHeadersDataRow curRow, List retList) {
Object[] newValues = new Object[3];
newValues[0] = view.getReview();
if(newValues[0] != null) {
newValues[0] = newValues[0].toString()
.replace("\n", " *LINE BREAK* ")
.replace("\r", " *LINE BREAK* ")
.replace("\t", " ")
.replace("\"", "");
}
newValues[1] = view.getAuthorId();
newValues[2] = view.getRepeatCount();
// copy the row so we dont mess up references
IHeadersDataRow rowCopy = curRow.copy();
rowCopy.addFields(newHeaders, newValues);
retList.add(rowCopy);
}
@Override
public void init(List
© 2015 - 2025 Weber Informatics LLC | Privacy Policy