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.Command;
 import base.json.Json;
 
 import java.util.Map;
 import java.util.UUID;
 
 import static base.jee.api.sql.util.Log.log;
 
 public class UpsertPersonSetting extends Command {
 
 	private SqlAPI api;
 	private UUID person;
 	private User user;
 	private String name;
 	private String value;
 
 	public UpsertPersonSetting(SqlAPI apiUser userUUID personString nameString valuethrows PermissionException {
 		this. = api;
 		this. = person;
 		this. = name;
 		this. = value;
 		this. = user;
 
 		if(person == null) {
 			throw new IllegalArgumentException("Invalid parameter: person");
 		}
 		if(api == null) {
 			throw new IllegalArgumentException("Invalid parameter: api");
 		}
 		if(user != null && !user.isAuthenticated()) {
 			throw new PermissionException(this.getClass().getSimpleName(), user"Requires an authenticated user.""");
 		}
 		if(name == null || name.length() == 0) {
 			throw new IllegalArgumentException("Invalid parameter: name");
 		}
 
 	}
 
 	public UpsertPersonSetting() {
 	}
 
 	public Command newWithParameters(Map<StringObjectparametersthrows PermissionException {
 		return new UpsertPersonSetting(
 				(SqlAPI)parameters.get("api"),
 				(User)parameters.get("user"),
 				UUID.fromString((String)parameters.get("person")),
 				(String)parameters.get("name"),
 				(String)parameters.get("value"));
 	}
 
 	protected void execute() throws IOException {
 		Connection c = null;
 		PreparedStatement s = null;
 
 		try {
 			c.setAutoCommit(false);
 
 				c.rollback();
 				log(c"WARN""Permission denied invoking: " + UpsertPersonSetting.class.getSimpleName() + " " + getJsonParameters());
 				c.commit();
 				throw new IllegalStateException("You do not have permission to manage settings.");
 			}
 
 			s = c.prepareStatement("delete from person_setting where uuid=? and name=?");
 			s.setString(2, );
 			s.execute();
 			s.close();
 			s = null;
 
 			if( != null) {
 				s = c.prepareStatement("insert into person_setting (uuid,name,value) values(?,?,?)");
 				s.setString(2, );
 				s.setString(3, );
 				s.execute();
 				s.close();
 				s = null;
 				log(c"INFO""Updated person setting {\"uuid\":\"" +  + "\",\"name\":\"" + Json.escape() + "\",\"value\":\"" + Json.escape() + "\"");
else {
				log(c"INFO""Cleared person setting {\"uuid\":\"" +  + "\",\"name\":\"" + Json.escape() + "\"");
			}
			c.commit();
			c.close();
			c = null;
catch(SQLException e) {
			throw new IOException(e);
finally {
			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 "{" +
				"\"requestor\":\"" +  + "\"," +
				"\"person\":\"" +  + "\"," +
				"\"name\":\"" + Json.escape() + "\"," +
				"\"value\":" + ( == null?"null":"\"" + Json.escape() + "\"") + "" +
				"}";
	}
New to GrepCode? Check out our FAQ X