X-Git-Url: https://git.pterodactylus.net/?a=blobdiff_plain;f=src%2Fnet%2Fpterodactylus%2Ffcp%2Fplugin%2FWebOfTrustPlugin.java;h=194952795eeb593bb27093651ed6de666180b4c4;hb=9be110e698b59932cb5818cb473653c367b8cad0;hp=233e72e25dd393cb8b39986bf68a7ab316c5362c;hpb=7efa77849ce98063396f86fde9bcc03918a217a6;p=jFCPlib.git diff --git a/src/net/pterodactylus/fcp/plugin/WebOfTrustPlugin.java b/src/net/pterodactylus/fcp/plugin/WebOfTrustPlugin.java index 233e72e..1949527 100644 --- a/src/net/pterodactylus/fcp/plugin/WebOfTrustPlugin.java +++ b/src/net/pterodactylus/fcp/plugin/WebOfTrustPlugin.java @@ -133,6 +133,46 @@ public class WebOfTrustPlugin { return ownIdentities; } + /** + * Returns the trust given to the identity with the given identifier by the + * given own identity. + * + * @param ownIdentity + * The own identity that is used to calculate trust values + * @param identifier + * The identifier of the identity whose trust to get + * @return The request identity trust + * @throws IOException + * if an I/O error occurs + * @throws FcpException + * if an FCP error occurs + */ + public IdentityTrust getIdentityTrust(OwnIdentity ownIdentity, String identifier) throws IOException, FcpException { + Map replies = fcpClient.sendPluginMessage("plugins.WoT.WoT", createParameters("Message", "GetIdentity", "TreeOwner", ownIdentity.getIdentifier(), "Identity", identifier)); + if (!replies.get("Message").equals("Identity")) { + throw new FcpException("WebOfTrust Plugin did not reply with “Identity” message!"); + } + Byte trust = null; + try { + trust = Byte.valueOf(replies.get("Trust")); + } catch (NumberFormatException nfe1) { + /* ignore. */ + } + Integer score = null; + try { + score = Integer.valueOf(replies.get("Score")); + } catch (NumberFormatException nfe1) { + /* ignore. */ + } + Integer rank = null; + try { + rank = Integer.valueOf(replies.get("Rank")); + } catch (NumberFormatException nfe1) { + /* ignore. */ + } + return new IdentityTrust(trust, score, rank); + } + // // PRIVATE METHODS // @@ -171,15 +211,6 @@ public class WebOfTrustPlugin { /** The identity’s request URI. */ private final String requestUri; - /** The identity’s trust value. */ - private final Byte trust; - - /** The identity’s score value. */ - private final Integer score; - - /** The identity’s rank. */ - private final Integer rank; - /** * Creates a new identity. * @@ -189,20 +220,11 @@ public class WebOfTrustPlugin { * The nickname of the identity * @param requestUri * The request URI of the identity - * @param trust - * The trust value of the identity - * @param score - * The score value of the identity - * @param rank - * The rank of the identity */ - public Identity(String identifier, String nickname, String requestUri, Byte trust, Integer score, Integer rank) { + public Identity(String identifier, String nickname, String requestUri) { this.identifier = identifier; this.nickname = nickname; this.requestUri = requestUri; - this.trust = trust; - this.score = score; - this.rank = rank; } /** @@ -232,6 +254,40 @@ public class WebOfTrustPlugin { return requestUri; } + } + + /** + * Container that stores the trust given to an identity. + * + * @author David ‘Bombe’ Roden <bombe@freenetproject.org> + */ + public static class IdentityTrust { + + /** The identity’s trust value. */ + private final Byte trust; + + /** The identity’s score value. */ + private final Integer score; + + /** The identity’s rank. */ + private final Integer rank; + + /** + * Creates a new identity trust container. + * + * @param trust + * The trust value of the identity + * @param score + * The score value of the identity + * @param rank + * The rank of the identity + */ + public IdentityTrust(Byte trust, Integer score, Integer rank) { + this.trust = trust; + this.score = score; + this.rank = rank; + } + /** * Returns the trust value of this identity. * @@ -269,16 +325,7 @@ public class WebOfTrustPlugin { * * @author David ‘Bombe’ Roden <bombe@freenetproject.org> */ - public static class OwnIdentity { - - /** The identity’s identifier. */ - private final String identifier; - - /** The identity’s nickname. */ - private final String nickname; - - /** The identity’s request URI. */ - private final String requestUri; + public static class OwnIdentity extends Identity { /** The identity’s insert URI. */ private final String insertUri; @@ -296,40 +343,11 @@ public class WebOfTrustPlugin { * The insert URI of the identity */ public OwnIdentity(String identifier, String nickname, String requestUri, String insertUri) { - this.identifier = identifier; - this.nickname = nickname; - this.requestUri = requestUri; + super(identifier, nickname, requestUri); this.insertUri = insertUri; } /** - * Returns the identifier of this identity. - * - * @return This identity’s identifier - */ - public String getIdentifier() { - return identifier; - } - - /** - * Returns the nickname of this identity. - * - * @return This identity’s nickname - */ - public String getNickname() { - return nickname; - } - - /** - * Returns the request URI of this identity. - * - * @return This identity’s request URI - */ - public String getRequestUri() { - return requestUri; - } - - /** * Returns the insert URI of this identity. * * @return This identity’s insert URI