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

base.jee.api.cassandra.GetGroupMembers 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 base.Query;
import base.jee.Constants;
import base.security.PermissionException;
import base.security.Person;
import base.security.User;
import com.datastax.driver.core.PreparedStatement;
import com.datastax.driver.core.Row;
import com.datastax.driver.core.Session;

import java.io.IOException;
import java.util.Collections;
import java.util.LinkedList;
import java.util.List;
import java.util.Map;
import java.util.UUID;

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

public class GetGroupMembers extends Query {

	private CassandraAPI api;
	private User user;
	private UUID group;

	public GetGroupMembers() {
	}

	public GetGroupMembers(CassandraAPI api, User user, UUID group) throws PermissionException {

		if(api == null) {
			throw new IllegalArgumentException("Invalid parameter: api");
		}
		if(group == null) {
			throw new IllegalArgumentException("Invalid parameter: group");
		}
		if(user == null || !user.isAuthenticated()) {
			throw new PermissionException(getClass().getSimpleName(), user, "Requires authenticated user.", Constants.GROUP_MANAGE_ROLE);
		}

		this.api = api;
		this.user = user;
		this.group = group;
	}

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

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

		boolean userInGroup = false;
		PreparedStatement q = s.prepare("select first_name, last_name from person where uuid=?");
		for(Row r : s.execute(s.prepare("select person_uuid from group_member where group_uuid=? allow filtering").bind(group))) {
			for(Row r2 : s.execute(q.bind(r.getUUID(0)))) {
				results.add(new Person(r.getUUID(0), r2.getString(0), r2.getString(1)));
			}
			if(r.getUUID(0).equals(user.getPersonUuid())) {
				userInGroup = true;
			}
		}

		if(user != null && !user.hasRole(Constants.GROUP_MANAGE_ROLE) && !userInGroup) {
			log(s, "WARN", user, "Permission denied invoking: " + GetSettings.class.getSimpleName() + " " + getJsonParameters());
			throw new IllegalStateException("You do not have permission to lookup this persons group information");
		}

		Collections.sort(results);

		return results;
	}

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

}




© 2015 - 2025 Weber Informatics LLC | Privacy Policy