/* ==================================================================== * Copyright (c) 1999, 2000 Ben Laurie. All rights reserved. * * Redistribution and use in source and binary forms, with or without * modification, are permitted provided that the following conditions * are met: * * 1. Redistributions of source code must retain the above copyright * notice, this list of conditions and the following disclaimer. * * 2. Redistributions in binary form must reproduce the above copyright * notice, this list of conditions and the following disclaimer in * the documentation and/or other materials provided with the * distribution. * * 3. All advertising materials mentioning features or use of this * software must display the following acknowledgment: * "This product includes software developed by Ben Laurie * for use in the Lucre project." * * 4. The name "Lucre" must not be used to * endorse or promote products derived from this software without * prior written permission. * * 5. Redistributions of any form whatsoever must retain the following * acknowledgment: * "This product includes software developed by Ben Laurie * for use in the Lucre project." * * THIS SOFTWARE IS PROVIDED BY BEN LAURIE ``AS IS'' AND ANY * EXPRESSED OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR * PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL BEN LAURIE OR * HIS CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, * SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT * NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; * LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, * STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) * ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED * OF THE POSSIBILITY OF SUCH DAMAGE. * ==================================================================== * * For more information on Lucre see http://anoncvs.aldigital.co.uk/lucre/. * */ package uk.co.aldigital.ben.lucre; import java.io.BufferedReader; import java.io.IOException; import java.io.PrintStream; import java.lang.Math; import java.math.BigInteger; class ZKVariant1Client { PublicCoinRequest m_req; PublicBank m_bank; BlindedCoin m_coin; BigInteger m_biChallenge; BigInteger m_biA; BigInteger m_biQ; BigInteger m_biResponse; ZKVariant1Client() { } ZKVariant1Client(PublicBank bank,PublicCoinRequest req,BlindedCoin coin) { m_bank=bank; m_req=req; m_coin=coin; } void generate() { m_biChallenge=BigInteger.valueOf(Math.abs(Util.randomGenerator().nextInt())%2); } void write(PrintStream str) { Util.dumpNumber(str,"challenge=",m_biChallenge); } void write(String szFile) throws IOException { write(Util.newFilePrintStream(szFile)); } void read(BufferedReader rdr) throws IOException { m_biChallenge=Util.readNumber(rdr,"challenge="); } void read(String szFile) throws IOException { read(Util.newBufferedFileReader(szFile)); } void readResponse(BufferedReader rdr) throws IOException { m_biResponse=Util.readNumber(rdr,"x="); } void readResponse(String szFile) throws IOException { readResponse(Util.newBufferedFileReader(szFile)); } void readCommitments(BufferedReader rdr) throws IOException { m_biQ=Util.readNumber(rdr,"Q="); m_biA=Util.readNumber(rdr,"A="); } void readCommitments(String szFile) throws IOException { readCommitments(Util.newBufferedFileReader(szFile)); } boolean verify() { BigInteger p=m_bank.getPrime(); if(m_biChallenge.equals(Util.ONE)) { // we chose t BigInteger t=m_biResponse; BigInteger tmp=m_biA.modPow(t,p); Util.dumpNumber("p= ",m_bank.getPublicKey()); Util.dumpNumber("tmp1=",tmp); if(!tmp.equals(m_bank.getPublicKey())) return false; tmp=m_biQ.modPow(t,p); Util.dumpNumber("s= ",m_coin.getSignature()); Util.dumpNumber("tmp2=",tmp); if(!tmp.equals(m_coin.getSignature())) return false; } else { // we chose r BigInteger r=m_biResponse; BigInteger tmp=m_req.getRequest().modPow(r,p); if(!tmp.equals(m_biQ)) return false; tmp=m_bank.getGenerator().modPow(r,p); if(!tmp.equals(m_biA)) return false; } return true; } }