*/
public class Identity {
+ /** The Web of Trust connector. */
+ protected final WebOfTrustConnector webOfTrustConnector;
+
/** The ID of the identity. */
private final String id;
/** The contexts of the identity. */
protected final Set<String> contexts = Collections.synchronizedSet(new HashSet<String>());
+ /** Whether the contexts have already been loaded. */
+ private volatile boolean contextsLoaded = false;
+
/** The properties of the identity. */
- private final Map<String, String> properties = Collections.synchronizedMap(new HashMap<String, String>());
+ protected final Map<String, String> properties = Collections.synchronizedMap(new HashMap<String, String>());
/**
* Creates a new identity.
*
+ * @param webOfTrustConnector
+ * The Web of Trust connector
* @param id
* The ID of the identity
* @param nickname
* @param requestUri
* The request URI of the identity
*/
- public Identity(String id, String nickname, String requestUri) {
+ public Identity(WebOfTrustConnector webOfTrustConnector, String id, String nickname, String requestUri) {
+ this.webOfTrustConnector = webOfTrustConnector;
this.id = id;
this.nickname = nickname;
this.requestUri = requestUri;
}
/**
- * Returns the contexts of the identity.
+ * Returns the contexts of the identity. If the contexts have not been
+ * loaded yet, they will be loaded. If loading the contexts fails, an empty
+ * set is returned.
*
* @return The contexts of the identity
*/
public Set<String> getContexts() {
+ try {
+ return getContexts(false);
+ } catch (PluginException pe1) {
+ return Collections.emptySet();
+ }
+ }
+
+ /**
+ * Returns the contexts of the identity.
+ *
+ * @param forceReload
+ * {@code true} to force a reload of the contexts
+ * @return The contexts of the identity
+ * @throws PluginException
+ * if an error occured communicating with the Web of Trust
+ * plugin
+ */
+ public Set<String> getContexts(boolean forceReload) throws PluginException {
+ if (!contextsLoaded || forceReload) {
+ Set<String> contexts = webOfTrustConnector.loadIdentityContexts(this);
+ contextsLoaded = true;
+ this.contexts.clear();
+ this.contexts.addAll(contexts);
+ }
return Collections.unmodifiableSet(contexts);
}
* {@code false} otherwise
*/
public boolean hasContext(String context) {
- return contexts.contains(context);
+ return getContexts().contains(context);
}
/**
return properties.get(name);
}
- /**
- * Sets the property with the given name to the given value.
- *
- * @param name
- * The name of the property to set
- * @param value
- * The new value of the property
- */
- public void setProperty(String name, String value) {
- properties.put(name, value);
- /* TODO - set property. */
- }
-
- /**
- * Removes the property with the given name.
- *
- * @param name
- * The name of the property to remove
- */
- public void removeProperty(String name) {
- properties.remove(name);
- /* TODO - remove property. */
- }
-
//
// OBJECT METHODS
//