*/
public class Identity {
- /** The Web of Trust connector. */
- protected final WebOfTrustConnector webOfTrustConnector;
-
/** The ID of the identity. */
private final String id;
private final String requestUri;
/** 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;
+ private final Set<String> contexts = Collections.synchronizedSet(new HashSet<String>());
/** The properties of the identity. */
private 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(WebOfTrustConnector webOfTrustConnector, String id, String nickname, String requestUri) {
- this.webOfTrustConnector = webOfTrustConnector;
+ public Identity(String id, String nickname, String requestUri) {
this.id = id;
this.nickname = nickname;
this.requestUri = requestUri;
}
/**
- * Returns the contexts of the identity.
+ * Returns all contexts of this identity.
*
- * @return The contexts of the identity
- * @throws PluginException
- * if an error occured communicating with the Web of Trust
- * plugin
+ * @return All contexts of this identity
*/
- public Set<String> getContexts() throws PluginException {
- return getContexts(false);
+ public Set<String> getContexts() {
+ return Collections.unmodifiableSet(contexts);
}
/**
- * Returns the contexts of the identity.
+ * Sets all contexts of this identity.
+ * <p>
+ * This method is only called by the {@link IdentityManager}.
*
- * @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);
+ * @param contexts
+ * All contexts of the identity
+ */
+ void setContexts(Set<String> contexts) {
+ this.contexts.clear();
+ this.contexts.addAll(contexts);
}
/**
- * Returns whether the identity contains the given context.
+ * Returns whether this identity has the given context.
*
* @param context
* The context to check for
}
/**
- * Returns the properties of the identity.
+ * Adds the given context to this identity.
+ * <p>
+ * This method is only called by the {@link IdentityManager}.
+ *
+ * @param context
+ * The context to add
+ */
+ void addContext(String context) {
+ contexts.add(context);
+ }
+
+ /**
+ * Removes the given context from this identity.
+ * <p>
+ * This method is only called by the {@link IdentityManager}.
*
- * @return The properties of the identity
+ * @param context
+ * The context to remove
+ */
+ void removeContext(String context) {
+ contexts.remove(context);
+ }
+
+ /**
+ * Returns all properties of this identity.
+ *
+ * @return All properties of this identity
*/
public Map<String, String> getProperties() {
- return Collections.unmodifiableMap(properties);
+ synchronized (properties) {
+ return Collections.unmodifiableMap(properties);
+ }
}
/**
- * Returns the value of the property with the given name.
+ * Sets all properties of this identity.
+ * <p>
+ * This method is only called by the {@link IdentityManager}.
*
- * @param name
- * The name of the property
- * @return The value of the property, or {@code null} if there is no such
- * property
+ * @param properties
+ * The new properties of this identity
*/
- public String getProperty(String name) {
- return properties.get(name);
+ void setProperties(Map<String, String> properties) {
+ synchronized (this.properties) {
+ this.properties.clear();
+ this.properties.putAll(properties);
+ }
}
/**
* Sets the property with the given name to the given value.
+ * <p>
+ * This method is only called by the {@link IdentityManager}.
*
* @param name
- * The name of the property to set
+ * The name of the property
* @param value
- * The new value of the property
+ * The value of the property
*/
- public void setProperty(String name, String value) {
- properties.put(name, value);
- /* TODO - set property. */
+ void setProperty(String name, String value) {
+ synchronized (properties) {
+ properties.put(name, value);
+ }
+ }
+
+ /**
+ * Returns the value of the property with the given name.
+ *
+ * @param name
+ * The name of the property
+ * @return The value of the property
+ */
+ public String getProperty(String name) {
+ synchronized (properties) {
+ return properties.get(name);
+ }
}
/**
* Removes the property with the given name.
+ * <p>
+ * This method is only called by the {@link IdentityManager}.
*
* @param name
* The name of the property to remove
*/
- public void removeProperty(String name) {
- properties.remove(name);
- /* TODO - remove property. */
+ void removeProperty(String name) {
+ synchronized (properties) {
+ properties.remove(name);
+ }
}
//
return identity.id.equals(id);
}
+ /**
+ * {@inheritDoc}
+ */
+ @Override
+ public String toString() {
+ return getClass().getSimpleName() + "[id=" + id + ",nickname=" + nickname + ",contexts=" + contexts + ",properties=" + properties + "]";
+ }
+
}