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 java.util.Date;
 import java.util.Map;
 
 
 import base.Command;
 import base.uuid.UUID;
 
 import static base.jee.api.sql.util.Log.log;

Send an email. Email is not immediately sent, but stored in an email delivery queue.
 
 public class SendEmail extends Command {
 
 	private DataSource ds;
 	private User user;
 	private Email email;
 
 	public SendEmail(DataSource dsUser userString emailthrows IOException {
 		if(ds == null) {
 			throw new IllegalArgumentException("Invalid parameter: ds");
 		}
 		if(user == null || !user.isAuthenticated()) {
 			throw new PermissionException(this.getClass().getSimpleName(), user"Requires an authenticated user.""");
 		}
 		if(email == null || email.length() == 0) {
 			throw new IllegalArgumentException("Invalid parameter: email");
 		}
 
 		this. = ds;
 		this. = user;
 		this. = new Email(email);
 	}
 
 	public Command newWithParameters(Map<StringObjectparametersthrows IOException {
 		return new SendEmail(
 				((SqlAPI)parameters.get("api")).getDataSource(),
 				(User)parameters.get("user"),
 				(String)parameters.get("email"));
 	}
 
 	protected void execute() throws IOException {
 		Connection c = null;
 		PreparedStatement s = null;
 
 		try {
 			c = .getConnection();
 			c.setAutoCommit(false);
 
 			if(!.isAuthenticated()) {
 				c.rollback();
 				log(c"WARN""Permission denied invoking: " + SendEmail.class.getSimpleName() + " " + getJsonParameters());
 				c.commit();
 				throw new IllegalStateException("You do not have permission to send email.");
 			}
 
 			s = c.prepareStatement("insert into email (uuid,to_address,email,retries,attempt_at,in_progress) values(?,?,?,0,?,0)");
 			s.setString(1, new UUID().toString());
 			s.setString(2, .getTo());
 			s.setString(3, .toJson());
 			s.setLong(4, new Date().getTime());
 			s.execute();
 			s.close();
 			s = null;
 
 			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 "{" +
				"\"person\":" + .getPersonUuid() + "" +
				"}";
	}
New to GrepCode? Check out our FAQ X