/*
* Sone - Identity.java - Copyright © 2010–2012 David Roden
*
* This program is free software: you can redistribute it and/or modify
* it under the terms of the GNU General Public License as published by
* the Free Software Foundation, either version 3 of the License, or
* (at your option) any later version.
*
* This program is distributed in the hope that it will be useful,
* but WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
* GNU General Public License for more details.
*
* You should have received a copy of the GNU General Public License
* along with this program. If not, see <http://www.gnu.org/licenses/>.
*/
package de.todesbaum.util.freenet.fcp2.wot;
import java.util.Collection;
import java.util.Map;
import java.util.Set;
/**
* Interface for web of trust identities, defining all functions that can be
* performed on an identity. An identity is only a container for identity data
* and will not perform any updating in the WebOfTrust plugin itself.
*
* @author <a href="mailto:bombe@pterodactylus.net">David ‘Bombe’ Roden</a>
*/
public interface Identity {
/**
* Returns the ID of the identity.
*
* @return The ID of the identity
*/
public String getId();
/**
* Returns the nickname of the identity.
*
* @return The nickname of the identity
*/
public String getNickname();
/**
* Returns the request URI of the identity.
*
* @return The request URI of the identity
*/
public String getRequestUri();
/**
* Returns all contexts of this identity.
*
* @return All contexts of this identity
*/
public Set<String> getContexts();
/**
* Returns whether this identity has the given context.
*
* @param context
* The context to check for
* @return {@code true} if this identity has the given context,
* {@code false} otherwise
*/
public boolean hasContext(String context);
/**
* Adds the given context to this identity.
*
* @param context
* The context to add
*/
public void addContext(String context);
/**
* Sets all contexts of this identity.
*
* @param contexts
* All contexts of the identity
*/
public void setContexts(Collection<String> contexts);
/**
* Removes the given context from this identity.
*
* @param context
* The context to remove
*/
public void removeContext(String context);
/**
* Returns all properties of this identity.
*
* @return All properties of this identity
*/
public Map<String, String> getProperties();
/**
* 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);
/**
* Sets the property with the given name to the given value.
*
* @param name
* The name of the property
* @param value
* The value of the property
*/
public void setProperty(String name, String value);
/**
* Sets all properties of this identity.
*
* @param properties
* The new properties of this identity
*/
public void setProperties(Map<String, String> properties);
/**
* Removes the property with the given name.
*
* @param name
* The name of the property to remove
*/
public void removeProperty(String name);
/**
* Retrieves the trust that this identity receives from the given own
* identity. If this identity is not in the own identity’s trust tree, a
* {@link Trust} is returned that has all its elements set to {@code null}.
* If the trust can not be retrieved, {@code null} is returned.
*
* @param ownIdentity
* The own identity to get the trust for
* @return The trust assigned to this identity, or {@code null} if the trust
* could not be retrieved
*/
public Trust getTrust(OwnIdentity ownIdentity);
/**
* Sets the trust given by an own identity to this identity.
*
* @param ownIdentity
* The own identity that gave trust to this identity
* @param trust
* The trust given by the given own identity
*/
public void setTrust(OwnIdentity ownIdentity, Trust trust);
/**
* Removes trust assignment from the given own identity for this identity.
*
* @param ownIdentity
* The own identity that removed the trust assignment for this
* identity
*/
public void removeTrust(OwnIdentity ownIdentity);
}