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.List;
 import java.util.Map;
 import java.util.UUID;
 
 import static base.jee.api.sql.util.Log.log;
 
 public class GetBatchResults extends Query<StringQueryResult> {
 
 	private SqlAPI api;
 	private User user;
 	private UUID batch;
 
 	public GetBatchResults(SqlAPI apiUser userUUID batchthrows PermissionException {
 		this. = api;
 		this. = user;
 		this. = batch;
 
 		if(api == null) {
 			throw new IllegalArgumentException("\"api\" parameter must not be null.");
 		}
 		if(user == null || !user.isAuthenticated()) {
 			throw new PermissionException(this.getClass().getSimpleName(), user"You don't have permission to complete this operation."null);
 		}
 		if(batch == null) {
 			throw new IllegalArgumentException("Please specify batch uuid.");
 		}
 
 	}
 
 	public GetBatchResults() {
 	}
 
 	public Query newWithParameters(Map<StringObjectparametersthrows PermissionException {
 		return new GetBatchResults(
 				(SqlAPI)parameters.get("api"),
 				(User)parameters.get("user"),
 				UUID.fromString((Stringparameters.get("batch")));
 	}
 
 	public List<StringQueryResultexecute() throws IOException {
 		List<StringQueryResultresults = new LinkedList<>();
 		Connection c = null;
 		PreparedStatement s = null;
 		PreparedStatement t = null;
 		ResultSet r = null;
 
 		try {
 			c.setAutoCommit(false);
 
 			UUID requestor = null;
 			s = c.prepareStatement("select requestor, executed from batch_load_info where uuid=?");
 			r = s.executeQuery();
 			if(r.next()) {
 				requestor = UUID.fromString(r.getString(1));
 			}
 			r.close();
 			r = null;
 			s.close();
 			s = null;
 
 			if(!.hasRole(.) && !.getPersonUuid().equals(requestor)) {
 				log(c"WARN""Permission denied invoking: " + GetBatchResults.class.getSimpleName() + " " + getJsonParameters());
 				c.commit();
 				throw new PermissionException(this.getClass().getSimpleName(), "You do not have permission to access audit information.".);
 			}
 
 			t = c.prepareStatement("select value from batch_load_result where uuid=? order by sort_order");
 			r = t.executeQuery();
 			while(r.next()) {
 				results.add(new StringQueryResult(r.getString(1)));
 			}
 			r.close();
 			r = null;
 			t.close();
			t = 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(t != null) { try { t.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