base.jee.api.cassandra.RecentLogEntriesByIP Maven / Gradle / Ivy
/**
* Creative commons Attribution-NonCommercial license.
*
* http://creativecommons.org/licenses/by-nc/2.5/au/deed.en_GB
*
* NO WARRANTY IS GIVEN OR IMPLIED, USE AT YOUR OWN RISK.
*/
package base.jee.api.cassandra;
import base.Query;
import base.jee.Constants;
import base.jee.api.cassandra.util.Log;
import base.jee.api.model.AuditLogEntry;
import base.security.PermissionException;
import base.security.User;
import base.text.TagsToArray;
import base.uuid.TimeUUIDToDate;
import com.datastax.driver.core.PreparedStatement;
import com.datastax.driver.core.ResultSet;
import com.datastax.driver.core.Row;
import com.datastax.driver.core.Session;
import java.io.IOException;
import java.util.Calendar;
import java.util.Date;
import java.util.GregorianCalendar;
import java.util.LinkedList;
import java.util.List;
import java.util.Map;
import static base.jee.api.cassandra.util.Log.log;
public class RecentLogEntriesByIP extends Query {
private CassandraAPI api;
private User user;
private String ip;
private long limit;
private boolean debug;
public RecentLogEntriesByIP(CassandraAPI api, User user, String ip, boolean debug, long limit) {
this.api = api;
this.user = user;
this.ip = ip;
this.limit = limit;
this.debug = debug;
if(api == null) {
throw new IllegalArgumentException("Invalid parameter: api");
}
if(user == null || !user.isAuthenticated()) {
throw new IllegalArgumentException("Requires an authenticated user.");
}
if(ip == null || ip.length() == 0) {
throw new IllegalArgumentException("Please specify a valid IP address.");
}
if(limit == 0) {
throw new IllegalArgumentException("Please specify a limit");
}
if(limit > 20000) {
throw new IllegalArgumentException("Limit must be less than 20,000.");
}
}
public RecentLogEntriesByIP() {
}
@Override
public Query newWithParameters(Map parameters) {
return new RecentLogEntriesByIP(
(CassandraAPI)parameters.get("api"),
(User)parameters.get("user"),
(String)parameters.get("ip"),
parameters.get("debug") != null && ((String)parameters.get("debug")).equalsIgnoreCase("true"),
Integer.parseInt((String)parameters.get("limit")));
}
public List execute() throws IOException {
List results = new LinkedList<>();
Session s = api.getCassandraSession();
if(!user.hasRole(Constants.AUDIT_ROLE)) {
log(s, "WARN", user, "Permission denied invoking: " + RecentLogEntries.class.getSimpleName() + " " + getJsonParameters());
throw new PermissionException(this.getClass().getSimpleName(), user, "You do not have permission to access audit information.", Constants.AUDIT_ROLE);
}
// Exclude particular IP's from appearing in the general log entry search results.
String[] hiddenIP = TagsToArray.tagsToArray(api.getSettingsCache().get("log.hidden.ip", ""));
Date date = new Date();
Calendar c = new GregorianCalendar();
c.setTime(date);
int dayCount = 0;
ResultSet rs;
PreparedStatement p = s.prepare(
"select uuid,level,person_uuid,first_name,last_name,message,ip "+
"from audit_event " +
"where yyyymmdd = ?" +
"order by uuid desc " +
"limit " + limit);
while(results.size() < limit && dayCount < 20) {
rs = s.execute(p.bind(Log.YYYYMMDD.format(date)));
for(Row r : rs) {
boolean skip = false;
for(String ip : hiddenIP) {
if(ip.equals(r.getString(6))) {
skip = true;
break;
}
}
if(!debug && r.getString(1).equalsIgnoreCase("debug")) {
skip = true;
}
if(!ip.equals(r.getString(6))) {
skip = true;
}
if(!skip) {
results.add(new AuditLogEntry(r.getUUID(0), new Date(TimeUUIDToDate.getTimeFromUUID(r.getUUID(0))), r.getString(1), r.getUUID(2), r.getString(3), r.getString(4), r.getString(5), r.getString(6)));
}
}
c.add(Calendar.DAY_OF_YEAR, -1);
date = c.getTime();
dayCount++;
}
return results;
}
@Override
public String getJsonParameters() {
return "{" +
"}";
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy