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

edu.ucsf.vitro.opensocial.GadgetSpec Maven / Gradle / Ivy

package edu.ucsf.vitro.opensocial;

import java.sql.Connection;
import java.sql.ResultSet;
import java.sql.SQLException;
import java.sql.Statement;
import java.util.ArrayList;
import java.util.HashMap;
import java.util.List;
import java.util.Map;

import org.apache.commons.dbcp2.BasicDataSource;

public class GadgetSpec {
	private int appId = 0;
	private String name;
	private String openSocialGadgetURL;
	private List channels = new ArrayList();
	private Map viewRequirements = new HashMap();
	boolean enabled;
	private boolean unknownGadget = false;

	public GadgetSpec(int appId, String name, String openSocialGadgetURL,
			List channels, BasicDataSource ds, boolean enabled, boolean unknownGadget)
			throws SQLException {
		this.appId = appId;
		this.name = name;
		this.openSocialGadgetURL = openSocialGadgetURL;
		this.channels.addAll(channels);
		this.enabled = enabled;
		this.unknownGadget = unknownGadget;

		// Load gadgets from the DB first
		if (!unknownGadget) {

			String sqlCommand = "select page, viewer_req, owner_req, view, chromeId, opt_params, display_order from orng_app_views where appId = " + appId;
			try (Connection conn = ds.getConnection()) {
				try (Statement stmt = conn.createStatement()) {
					try (ResultSet rset = stmt.executeQuery(sqlCommand)) {
						while (rset.next()) {
							viewRequirements.put(
									rset.getString(1),
									new GadgetViewRequirements(rset.getString(1), rset
											.getString(2), rset.getString(3), rset
											.getString(4), rset.getString(5), rset
											.getString(6), rset.getInt(7)));
						}
					}
				}
			}
		}
	}

	public int getAppId() {
		return appId;
	}

	public String getName() {
		return name;
	}

	public String getGadgetURL() {
		return openSocialGadgetURL;
	}

	public List getChannels() {
		return channels;
	}

	public boolean listensTo(String channel) { // if an unknownd gadget just say yes,
												// we don't care about
												// performance in this situation
		return unknownGadget || channels.contains(channel);
	}

	public GadgetViewRequirements getGadgetViewRequirements(String page) {
		if (viewRequirements.containsKey(page)) {
			return viewRequirements.get(page);
		}
		return null;
	}

	public boolean show(String viewerId, String ownerId, String page,
			BasicDataSource ds) throws SQLException {
		boolean show = true;
		// if there are no view requirements, go ahead and show it. We are
		// likely testing out a new gadget
		// if there are some, turn it off unless this page is
		if (viewRequirements.size() > 0) {
			show = false;
		}

		if (viewRequirements.containsKey(page)) {
			show = true;
			GadgetViewRequirements req = getGadgetViewRequirements(page);
			if ('U' == req.getViewerReq() && viewerId == null) {
				show = false;
			} else if ('R' == req.getViewerReq()) {
				show &= isRegisteredTo(viewerId, ds);
			}
			if ('R' == req.getOwnerReq()) {
				show &= isRegisteredTo(ownerId, ds);
			} else if ('S' == req.getOwnerReq()) {
				show &= (viewerId.equals(ownerId));
			}
		}
		return show;
	}

	public boolean isRegisteredTo(String personId, BasicDataSource ds)
			throws SQLException {
		int count = 0;

		String sqlCommand = "select count(*) from orng_app_registry where appId = " + getAppId() + " and personId = '" + personId + "';";

		try (Connection conn = ds.getConnection()) {
			try (Statement stmt = conn.createStatement()) {
				try (ResultSet rset = stmt.executeQuery(sqlCommand)) {
					while (rset.next()) {
						count = rset.getInt(1);
					}
				}
			}
		}

		return (count == 1);
	}

	public boolean fromSandbox() {
		return unknownGadget;
	}

	public boolean isEnabled() {
		return enabled;
	}

	// who sees it? Return the viewerReq for the ProfileDetails page
	public char getVisibleScope() {
		GadgetViewRequirements req = getGadgetViewRequirements("/display");
		return req != null ? req.getViewerReq() : ' ';
	}

	public String toString() {
		return "" + this.appId + ":" + this.name + ":" + this.openSocialGadgetURL;
	}

}




© 2015 - 2024 Weber Informatics LLC | Privacy Policy