All Downloads are FREE. Search and download functionalities are using the official Maven repository.

base.jee.api.cassandra.GetPersonByEmail 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 java.io.IOException;

import base.Query;
import com.datastax.driver.core.Row;
import com.datastax.driver.core.Session;
import com.datastax.driver.core.PreparedStatement;
import java.util.Date;
import java.util.LinkedList;
import java.util.List;
import java.util.Map;

import base.jee.Constants;
import base.json.Json;
import base.security.PermissionException;
import base.security.Person;
import base.security.User;

import static base.jee.api.cassandra.util.Log.log;

/**
 * Return the personal details associated with a particular person. A user
 * may only lookup the details associated with their own account unless they
 * have the Types.PERSON_MANAGE permission.
 */
public class GetPersonByEmail extends Query {

	private CassandraAPI api;
	private User user;
	private String email;

	public GetPersonByEmail(CassandraAPI api, User user, String email) throws PermissionException {

		if(api == null) {
			throw new IllegalArgumentException("Invalid parameter: api");
		}
		if(user == null || !user.isAuthenticated()) {
			throw new PermissionException(getClass().getSimpleName(), user, "Authenticate before invoking this command.", null);
		}

		this.api = api;
		this.user = user;
		this.email = email;
	}

	public GetPersonByEmail() {
	}

	@Override
	public Query newWithParameters(Map parameters) throws PermissionException {
		return new GetPersonByEmail(
				(CassandraAPI)parameters.get("api"),
				(User)parameters.get("user"),
				(String)parameters.get("email"));
	}

	public List execute() throws IOException {
		List results = new LinkedList<>();
		Session s = api.getCassandraSession();

		if(!user.hasRole(Constants.PERSON_MANAGE_ROLE)) {
			log(s, "WARN", user, "Permission denied invoking: " + GetPersonByEmail.class.getSimpleName() + " " + getJsonParameters());
			throw new PermissionException(this.getClass().getSimpleName(), user, "You do not have permission to view this persons account details.", Constants.PERSON_MANAGE_ROLE);
		}

		PreparedStatement q = s.prepare(
				"select uuid, first_name, last_name, email, username, last_auth, last_auth_ip, created, updated, expiry "+
				"from  person "+
						"where email = ?");
		for(Row r : s.execute(q.bind(email))) {
			Person p = new Person();
			p.setUuid(r.getUUID(0));
			p.setFirstName(r.getString(1));
			p.setLastName(r.getString(2));
			p.setEmail(r.getString(3));
			p.setUsername(r.getString(4));
			if(r.getLong(5) != 0) {
				p.setLastAuth(new Date(r.getLong(5)));
			}
			p.setLastAuthIp(r.getString(6));
			p.setCreated(new Date(r.getLong(7)));
			p.setUpdated(new Date(r.getLong(8)));
			if(r.getLong(9) > 0) {
				p.setExpiry(new Date(r.getLong(9)));
			}
			results.add(p);
		}

		return results;
	}

	@Override
	public String getJsonParameters() {
		return "{" +
				"\"person\":" + user.getPersonUuid() + "," +
				"\"email\":\"" + Json.escape(email) + "\"" +
				"}";
	}

}




© 2015 - 2025 Weber Informatics LLC | Privacy Policy