29.07.2013 Views

Master of Science thesis Fighting Spam

Master of Science thesis Fighting Spam

Master of Science thesis Fighting Spam

SHOW MORE
SHOW LESS

You also want an ePaper? Increase the reach of your titles

YUMPU automatically turns print PDFs into web optimized ePapers that Google loves.

import <strong>Spam</strong>Cash.Utilities.Cryptotools;<br />

import org.logi.crypto.sign.BlindSignature;<br />

public class BlindedCoin implements java.io.Serializable<br />

{<br />

private byte[] bf1,bf2;<br />

private String hashFunc,blindFunc;<br />

private String signatureHashFunc;<br />

private byte[] blindSignature1,blindSignature2;<br />

public BlindedCoin(BlindFingerprint bf1,BlindFingerprint bf2)<br />

{<br />

this.bf1 = bf1.getBytes();<br />

this.bf2 = bf2.getBytes();<br />

this.hashFunc = bf1.getHashFunc();<br />

this.blindFunc = bf1.getBlindFunc();<br />

}<br />

protected Signature getSignature1(RSAPublicKey pub,RSAPrivateKey<br />

priv,RSABlindingFactor factor) throws Exception<br />

{<br />

return<br />

Cryptotools.unblind(pub,Cryptotools.blindSign(priv,getFingerprint1()),factor);<br />

}<br />

protected Signature getSignature2(RSAPublicKey pub,RSAPrivateKey<br />

priv,RSABlindingFactor factor) throws Exception<br />

{<br />

return<br />

Cryptotools.unblind(pub,Cryptotools.blindSign(priv,getFingerprint2()),factor);<br />

}<br />

public Signature getAndUnblindSignature1(RSAPublicKey pub, RSABlindingFactor factor)<br />

throws Exception<br />

{<br />

return Cryptotools.unblind(pub,new<br />

BlindSignature(hashFunc,blindFunc,blindSignature1),factor);<br />

}<br />

public Signature getAndUnblindSignature2(RSAPublicKey pub, RSABlindingFactor factor)<br />

throws Exception<br />

{<br />

return Cryptotools.unblind(pub,new<br />

BlindSignature(hashFunc,blindFunc,blindSignature2),factor);<br />

}<br />

}<br />

public void blindSign(RSAPrivateKey privateKey) throws Exception<br />

{<br />

Signature b1 = Cryptotools.blindSign(privateKey, getFingerprint1());<br />

Signature b2 = Cryptotools.blindSign(privateKey, getFingerprint2());<br />

}<br />

this.blindSignature1 = b1.getBytes();<br />

this.blindSignature2 = b2.getBytes();<br />

this.signatureHashFunc = b1.getHashFunc();<br />

private BlindFingerprint getFingerprint1()<br />

{<br />

return new BlindFingerprint(hashFunc,blindFunc,bf1);<br />

}<br />

private BlindFingerprint getFingerprint2()<br />

{<br />

return new BlindFingerprint(hashFunc,blindFunc,bf2);<br />

}<br />

310

Hooray! Your file is uploaded and ready to be published.

Saved successfully!

Ooh no, something went wrong!