/** The logger. */
private static final Logger logger = Logging.getLogger(Sone.class);
+ /** The ID of this Sone. */
+ private final String id;
+
/** The identity of this Sone. */
- private final Identity identity;
+ private Identity identity;
/** The URI under which the Sone is stored in Freenet. */
private volatile FreenetURI requestUri;
/**
* Creates a new Sone.
*
- * @param identity
- * The identity of the Sone
+ * @param id
+ * The ID of the Sone
*/
- public Sone(Identity identity) {
- this.identity = identity;
+ public Sone(String id) {
+ this.id = id;
}
//
* @return The identity of this Sone
*/
public String getId() {
- return identity.getId();
+ return id;
}
/**
}
/**
+ * Sets the identity of this Sone. The {@link Identity#getId() ID} of the
+ * identity has to match this Sone’s {@link #getId()}.
+ *
+ * @param identity
+ * The identity of this Sone
+ * @return This Sone (for method chaining)
+ * @throws IllegalArgumentException
+ * if the ID of the identity does not match this Sone’s ID
+ */
+ public Sone setIdentity(Identity identity) throws IllegalArgumentException {
+ if (!identity.getId().equals(id)) {
+ throw new IllegalArgumentException("Identity’s ID does not match Sone’s ID!");
+ }
+ this.identity = identity;
+ return this;
+ }
+
+ /**
* Returns the name of this Sone.
*
* @return The name of this Sone
*/
public String getName() {
- return identity.getNickname();
+ return (identity != null) ? identity.getNickname() : null;
}
/**
*/
public Sone setRequestUri(FreenetURI requestUri) {
if (this.requestUri == null) {
- this.requestUri = requestUri;
+ this.requestUri = requestUri.setDocName("Sone").setMetaString(new String[0]);
return this;
}
if (!this.requestUri.equalsKeypair(requestUri)) {
*/
public Sone setInsertUri(FreenetURI insertUri) {
if (this.insertUri == null) {
- this.insertUri = insertUri;
+ this.insertUri = insertUri.setDocName("Sone").setMetaString(new String[0]);
return this;
}
if (!this.insertUri.equalsKeypair(insertUri)) {
*/
@Override
public int hashCode() {
- return identity.getId().hashCode();
+ return id.hashCode();
}
/**
if (!(object instanceof Sone)) {
return false;
}
- return ((Sone) object).identity.getId().equals(identity.getId());
+ return ((Sone) object).id.equals(id);
}
/**