Start line:  
End line:  

Snippet Preview

Snippet HTML Code

Stack Overflow Questions
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.sql;
  
 import base.Query;
 
 import java.util.Date;
 import java.util.List;
 import java.util.Map;
 import java.util.UUID;
 
 import static base.jee.api.sql.util.Log.log;
 
 public class RecentLogEntriesByIP extends Query<AuditLogEntry> {
 
 	private SqlAPI api;
 	private User user;
 	private String ip;
 	private long limit;
 	private boolean debug;
 
 	public RecentLogEntriesByIP(SqlAPI apiUser userString ipboolean debuglong limitthrows PermissionException {
 		this. = api;
 		this. = user;
 		this. = ip;
 		this. = limit;
 		this. = debug;
 
 		if(api == null) {
 			throw new IllegalArgumentException("\"api\" parameter must not be null.");
 		}
 		if(user == null || !user.isAuthenticated()) {
 			throw new PermissionException(this.getClass().getSimpleName(), user"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() {
 	}
 
 		return new RecentLogEntriesByIP(
 				(SqlAPI)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<AuditLogEntryexecute() throws IOException {
 		List<AuditLogEntryresults = new LinkedList<>();
 		Connection c = null;
 		PreparedStatement s = null;
 		ResultSet r = null;
 
 		try {
 			c.setAutoCommit(false);
 
 				log(c"WARN""Permission denied invoking: " + RecentLogEntriesByIP.class.getSimpleName() + " " + getJsonParameters());
 				c.commit();
 				throw new PermissionException(this.getClass().getSimpleName(), "You do not have permission to access audit information.".);
 			}
 
 			s = c.prepareStatement(
 					"select e.event_time,e.level,e.person_uuid,e.message,p.first_name,p.last_name,e.ip "+
 					"from audit_event e left join person p on (e.person_uuid = p.uuid) "+
 					"where e.ip = ? " +
 					(?"":"and e.level!='DEBUG' ") +
 					"order by e.event_time desc " +
 					"limit " + );
 			s.setString(1, );
 			r = s.executeQuery();
 			while(r.next()) {
				results.add(new AuditLogEntry(new Date(r.getLong(1)), r.getString(2), nullableUuid(r.getString(3)), r.getString(5), r.getString(6), r.getString(4), r.getString(7)));
			}
			r.close();
			r = null;
			s.close();
			s = null;
			c.commit();
			c.close();
			c = null;
catch(SQLException e) {
			throw new IOException(e);
finally {
			if(r != null) { try { r.close(); } catch(SQLException e) {} }
			if(s != null) { try { s.close(); } catch(SQLException e) {} }
			if(c != null) {
				try { c.rollback(); } catch (SQLException e) { }
				try { c.close(); } catch (SQLException e) { }
			}
		}
		return results;
	}
		return "{" +
				"}";
	}
	private UUID nullableUuid(String uuid) {
		if(uuid == null || uuid.length() == 0) {
			return null;
		}
		return UUID.fromString(uuid);
	}
New to GrepCode? Check out our FAQ X