message handler
parent
0a8d4abe72
commit
91dd19ead2
|
@ -6,6 +6,7 @@ import org.bouncycastle.util.Arrays;
|
||||||
import org.factcenter.qilin.primitives.concrete.Zpstar;
|
import org.factcenter.qilin.primitives.concrete.Zpstar;
|
||||||
|
|
||||||
import java.math.BigInteger;
|
import java.math.BigInteger;
|
||||||
|
import java.util.HashSet;
|
||||||
import java.util.Random;
|
import java.util.Random;
|
||||||
import java.util.Set;
|
import java.util.Set;
|
||||||
|
|
||||||
|
@ -14,44 +15,55 @@ import java.util.Set;
|
||||||
*
|
*
|
||||||
* an implementation of a version of Pedersen's distributed key generation protocol
|
* an implementation of a version of Pedersen's distributed key generation protocol
|
||||||
*/
|
*/
|
||||||
public class DKG extends VerifiableSecretSharing{
|
public class DKG extends VerifiableSecretSharing implements Runnable{
|
||||||
|
|
||||||
private Network.User user;
|
private Network.User user;
|
||||||
private Polynomial.Point[][] shares;
|
private Handler handler;
|
||||||
|
private Polynomial.Point[] shares;
|
||||||
private BigInteger[][] commitmentsArray;
|
private BigInteger[][] commitmentsArray;
|
||||||
|
private BigInteger[] ys;
|
||||||
private Set<Integer> QUAL;
|
private Set<Integer> QUAL;
|
||||||
|
|
||||||
private BigInteger x;
|
private BigInteger x;
|
||||||
private BigInteger y;
|
private BigInteger y;
|
||||||
private BigInteger[] commitments;
|
private BigInteger[] commitments;
|
||||||
|
|
||||||
public DKG(int t, int n, BigInteger x, Random random, BigInteger p, BigInteger q, BigInteger g) {
|
public DKG(int t, int n, BigInteger x, Random random, BigInteger p, BigInteger q, BigInteger g,Network network) {
|
||||||
super(t, n, x, random, p, q, g);
|
super(t, n, x, random, p, q, g);
|
||||||
|
this.commitmentsArray = new BigInteger[n][t + 1];
|
||||||
|
this.shares = new Polynomial.Point[n];
|
||||||
|
this.handler = new Handler();
|
||||||
|
this.user = network.connect(handler);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
private void stage1(){
|
private void stage1(){
|
||||||
int n = getN();
|
int n = getN();
|
||||||
|
int t = getT();
|
||||||
int i = user.getID();
|
int i = user.getID();
|
||||||
BigInteger[] commitments = super.getCommitments();
|
BigInteger[] commitments = super.getCommitments();
|
||||||
System.arraycopy(commitments, 0, commitmentsArray[i - 1], 0, commitmentsArray[i - 1].length);
|
System.arraycopy(commitments, 0, commitmentsArray[i - 1], 0, commitmentsArray[i - 1].length);
|
||||||
|
|
||||||
Network.Message message = null;
|
Network.CommitmentMessage commitment;
|
||||||
for (int j = 1; j <= commitmentsArray[i - 1].length; j ++){
|
for (int j = 1; j <= commitmentsArray[i - 1].length; j ++){
|
||||||
//message = new Message(Type.Commitment, Shares[i - 1][j - 1])
|
commitment = new Network.CommitmentMessage(j,commitmentsArray[i - 1][j - 1]);
|
||||||
user.sendBroadcast(message);
|
user.broadcast(commitment);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
Network.SecretMessage secret;
|
||||||
for (int j = 1; j <= shares[i - 1].length; j ++){
|
|
||||||
shares[i - 1][j - 1] = getShare(j);
|
|
||||||
}
|
|
||||||
for (int j = 1; j <= n ; j++ ){
|
for (int j = 1; j <= n ; j++ ){
|
||||||
if(j != i){
|
if(j != i){
|
||||||
//message = new Message(Type.Share, Shares[i - 1][j - 1])
|
secret = new Network.SecretMessage(getShare(j));
|
||||||
user.send(j,message);
|
user.send(j,secret);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
while (handler.secretsCounter < n - 1 || handler.commitmentsCounter < (n - 1) * (t + 1)){
|
||||||
|
try {
|
||||||
|
Thread.sleep(30);
|
||||||
|
} catch (InterruptedException e) {
|
||||||
|
// do nothing
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
//Todo receive messages
|
|
||||||
}
|
}
|
||||||
|
|
||||||
private void stage2(){
|
private void stage2(){
|
||||||
|
@ -59,35 +71,40 @@ public class DKG extends VerifiableSecretSharing{
|
||||||
BigInteger g = getGenerator();
|
BigInteger g = getGenerator();
|
||||||
Zpstar zpstar = getZpstar();
|
Zpstar zpstar = getZpstar();
|
||||||
int i = user.getID();
|
int i = user.getID();
|
||||||
|
QUAL = new HashSet<Integer>();
|
||||||
Network.Message message = null;
|
Network.Message message = null;
|
||||||
for (int j = 1; j <= n ; j++ ){
|
for (int j = 1; j <= n ; j++ ){
|
||||||
if(zpstar.multiply(g,shares[i - 1][j - 1].y).equals(verify(j,commitmentsArray[j],zpstar))){
|
if(zpstar.multiply(g,shares[j - 1].y).equals(verify(j,commitmentsArray[j],zpstar))){
|
||||||
QUAL.add(j);
|
QUAL.add(j);
|
||||||
}else{
|
}else{
|
||||||
//message = new Message(Type.Complaint, j)
|
//message = new Message(Type.Complaint, j)
|
||||||
user.sendBroadcast(message);
|
user.broadcast(message);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
//sending y after Complaints
|
||||||
|
Network.YMessage yMessage = new Network.YMessage(super.getY());
|
||||||
|
user.broadcast(yMessage);
|
||||||
}
|
}
|
||||||
|
|
||||||
private void stage3(){
|
private void stage3(){
|
||||||
|
int n = getN();
|
||||||
|
while (handler.ysCounter < n - 1 ){
|
||||||
|
try {
|
||||||
|
Thread.sleep(30);
|
||||||
|
} catch (InterruptedException e) {
|
||||||
|
// do nothing
|
||||||
|
}
|
||||||
|
}
|
||||||
//Todo receive something private from each complaint + send what necessary
|
//Todo receive something private from each complaint + send what necessary
|
||||||
|
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
private void stage4(){
|
private void stage4(){
|
||||||
Network.Message message = null;
|
int t = getT();
|
||||||
// message = new Message(Type.Y, super.getY())
|
|
||||||
user.sendBroadcast(message);
|
|
||||||
Zpstar zpstar = getZpstar();
|
Zpstar zpstar = getZpstar();
|
||||||
BigInteger y = zpstar.zero();
|
BigInteger y = zpstar.zero();
|
||||||
for (Network.User user:this.user.getNetwork()) {
|
for (int i : QUAL) {
|
||||||
//Todo receive yi from all i in QUAL and calc y total
|
y = zpstar.add(y , ys[i - 1]);
|
||||||
}
|
}
|
||||||
int t = getT();
|
|
||||||
this.commitments = new BigInteger[t];
|
this.commitments = new BigInteger[t];
|
||||||
BigInteger commitment;
|
BigInteger commitment;
|
||||||
for (int k = 1; k <= t ; k++){
|
for (int k = 1; k <= t ; k++){
|
||||||
|
@ -101,7 +118,7 @@ public class DKG extends VerifiableSecretSharing{
|
||||||
int j = user.getID();
|
int j = user.getID();
|
||||||
BigInteger x = BigInteger.ZERO;
|
BigInteger x = BigInteger.ZERO;
|
||||||
for (int i : QUAL) {
|
for (int i : QUAL) {
|
||||||
x = x.add(shares[i][j].y);
|
x = x.add(shares[i - 1].y);
|
||||||
}
|
}
|
||||||
this.x = x.mod(getQ());
|
this.x = x.mod(getQ());
|
||||||
}
|
}
|
||||||
|
@ -120,4 +137,54 @@ public class DKG extends VerifiableSecretSharing{
|
||||||
protected Polynomial.Point getShare(int i) {
|
protected Polynomial.Point getShare(int i) {
|
||||||
return null;
|
return null;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public void run() {
|
||||||
|
stage1();
|
||||||
|
stage2();
|
||||||
|
stage3();
|
||||||
|
stage4();
|
||||||
|
}
|
||||||
|
|
||||||
|
private class Handler implements Network.MailHandler {
|
||||||
|
|
||||||
|
final int id;
|
||||||
|
int secretsCounter;
|
||||||
|
int commitmentsCounter;
|
||||||
|
int ysCounter;
|
||||||
|
|
||||||
|
private Handler() {
|
||||||
|
this.id = user.getID();
|
||||||
|
this.secretsCounter = 0;
|
||||||
|
this.commitmentsCounter = 0;
|
||||||
|
this.ysCounter = 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public void handel(Network.Mail mail) {
|
||||||
|
if(mail.isPrivate){
|
||||||
|
if(mail.message instanceof Network.SecretMessage){
|
||||||
|
Polynomial.Point secret = ((Network.SecretMessage)mail.message).secret;
|
||||||
|
if(shares[id - 1] == null) {
|
||||||
|
shares[id - 1] = secret;
|
||||||
|
secretsCounter++;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}else{
|
||||||
|
if(mail.message instanceof Network.CommitmentMessage){
|
||||||
|
Network.CommitmentMessage commitmentMessage = (Network.CommitmentMessage)mail.message;
|
||||||
|
if(commitmentsArray[mail.senderID - 1][commitmentMessage.k] == null) {
|
||||||
|
commitmentsArray[mail.senderID - 1][commitmentMessage.k] = commitmentMessage.commitment;
|
||||||
|
commitmentsCounter++;
|
||||||
|
}
|
||||||
|
}else if(mail.message instanceof Network.YMessage){
|
||||||
|
BigInteger y = ((Network.YMessage)mail.message).y;
|
||||||
|
if(ys[mail.senderID - 1] == null){
|
||||||
|
ys[mail.senderID - 1] = y;
|
||||||
|
ysCounter ++;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -1,27 +1,147 @@
|
||||||
package JointFeldmanProtocol;
|
package JointFeldmanProtocol;
|
||||||
|
|
||||||
|
import FeldmanVerifiableSecretSharing.ShamirSecretSharing.Polynomial;
|
||||||
|
|
||||||
|
import java.lang.reflect.Type;
|
||||||
|
import java.math.BigInteger;
|
||||||
|
import java.util.Queue;
|
||||||
|
import java.util.concurrent.ArrayBlockingQueue;
|
||||||
/**
|
/**
|
||||||
* Created by Tzlil on 2/5/2016.
|
* Created by Tzlil on 2/7/2016.
|
||||||
*/
|
*/
|
||||||
public interface Network extends Iterable<Network.User>{
|
public class Network {
|
||||||
|
|
||||||
User connect();
|
private final User[] users;
|
||||||
|
private final int n;
|
||||||
|
private final Queue<Integer> availableIDs;
|
||||||
|
|
||||||
interface User{
|
|
||||||
int getID();
|
|
||||||
void send(int userID,Message message);
|
|
||||||
void sendBroadcast(Message message);
|
|
||||||
void receive(int userID,Message message);
|
|
||||||
void receiveBroadcast(Message message);
|
|
||||||
Network getNetwork();
|
|
||||||
}
|
|
||||||
|
|
||||||
interface Message{
|
|
||||||
enum Type {
|
|
||||||
Commitment, Share, Complaint, Y
|
|
||||||
}
|
|
||||||
|
|
||||||
Type getType();
|
|
||||||
|
|
||||||
|
public Network(int n) {
|
||||||
|
this.n = n;
|
||||||
|
this.users = new User[n];
|
||||||
|
this.availableIDs = new ArrayBlockingQueue<Integer>(n);
|
||||||
|
for (int id = 1; id <= n; id++){
|
||||||
|
availableIDs.add(id);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
public User connect(MailHandler messageHandler){
|
||||||
|
Integer id = availableIDs.poll();
|
||||||
|
if (id == null)
|
||||||
|
return null;
|
||||||
|
return new User(id,messageHandler);
|
||||||
|
}
|
||||||
|
|
||||||
|
private boolean sendMessage(User sender,int destination,Message message){
|
||||||
|
if(destination < 1 || destination > n)
|
||||||
|
return false;
|
||||||
|
User user = users[destination - 1];
|
||||||
|
if (user == null)
|
||||||
|
return false;
|
||||||
|
return user.mailbox.add(new Mail(sender.ID,false,message));
|
||||||
|
}
|
||||||
|
|
||||||
|
private void sendBroadcast(User sender,Message message){
|
||||||
|
User user;
|
||||||
|
int ID = sender.ID;
|
||||||
|
for (int i = 0 ; i < n ; i++){
|
||||||
|
if (i + 1 == ID) {
|
||||||
|
continue;
|
||||||
|
}
|
||||||
|
user = users[i];
|
||||||
|
user.mailbox.add(new Mail(ID,true,message));
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
public class User{
|
||||||
|
private final MailHandler messageHandler;
|
||||||
|
private final Queue<Mail> mailbox;
|
||||||
|
private final int ID;
|
||||||
|
|
||||||
|
public User(int ID, MailHandler messageHandler) {
|
||||||
|
this.mailbox = new ArrayBlockingQueue<Mail>(n*n);
|
||||||
|
this.ID = ID;
|
||||||
|
this.messageHandler = messageHandler;
|
||||||
|
Thread thread = new Thread(new Receiver());
|
||||||
|
thread.run();
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
public boolean send(int id, Message message){
|
||||||
|
return sendMessage(this,id,message);
|
||||||
|
}
|
||||||
|
public void broadcast(Message message){
|
||||||
|
sendBroadcast(this,message);
|
||||||
|
}
|
||||||
|
|
||||||
|
public int getID() {
|
||||||
|
return ID;
|
||||||
|
}
|
||||||
|
|
||||||
|
private class Receiver implements Runnable{
|
||||||
|
@Override
|
||||||
|
public void run() {
|
||||||
|
while (true){
|
||||||
|
if (!mailbox.isEmpty()){
|
||||||
|
messageHandler.handel(mailbox.poll());
|
||||||
|
}else{
|
||||||
|
try {
|
||||||
|
Thread.sleep(30);
|
||||||
|
} catch (InterruptedException e) {
|
||||||
|
// do nothing
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
public class Mail{
|
||||||
|
public final int senderID;
|
||||||
|
public final boolean isPrivate;
|
||||||
|
public final Message message;
|
||||||
|
|
||||||
|
private Mail(int senderID, boolean isPrivate, Message message) {
|
||||||
|
this.senderID = senderID;
|
||||||
|
this.isPrivate = isPrivate;
|
||||||
|
this.message = message;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
public static abstract class Message{
|
||||||
|
|
||||||
|
}
|
||||||
|
public static class CommitmentMessage extends Message{
|
||||||
|
public final int k;
|
||||||
|
public final BigInteger commitment;
|
||||||
|
|
||||||
|
|
||||||
|
public CommitmentMessage(int k, BigInteger commitment) {
|
||||||
|
this.k = k;
|
||||||
|
this.commitment = commitment;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
public static class YMessage extends Message{
|
||||||
|
|
||||||
|
public final BigInteger y;
|
||||||
|
|
||||||
|
public YMessage(BigInteger y) {
|
||||||
|
this.y = y;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
public static class SecretMessage extends Message{
|
||||||
|
public final Polynomial.Point secret;
|
||||||
|
|
||||||
|
public SecretMessage(Polynomial.Point secret) {
|
||||||
|
this.secret = secret;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
public interface MailHandler {
|
||||||
|
public void handel(Mail mail);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -1,8 +1,6 @@
|
||||||
package FeldmanVerifiableSecretSharing;
|
package FeldmanVerifiableSecretSharing;
|
||||||
|
|
||||||
import FeldmanVerifiableSecretSharing.ShamirSecretSharing.Polynomial;
|
import FeldmanVerifiableSecretSharing.ShamirSecretSharing.Polynomial;
|
||||||
import org.factcenter.qilin.primitives.CyclicGroup;
|
|
||||||
import org.factcenter.qilin.primitives.concrete.Zn;
|
|
||||||
import org.factcenter.qilin.primitives.concrete.Zpstar;
|
import org.factcenter.qilin.primitives.concrete.Zpstar;
|
||||||
import org.junit.Before;
|
import org.junit.Before;
|
||||||
import org.junit.Test;
|
import org.junit.Test;
|
||||||
|
@ -20,15 +18,20 @@ public class VerifiableSecretSharingTest {
|
||||||
int tests = 1 << 10;
|
int tests = 1 << 10;
|
||||||
Random random;
|
Random random;
|
||||||
|
|
||||||
//@Before
|
@Before
|
||||||
public void settings(){
|
public void settings(){
|
||||||
BigInteger p = BigInteger.valueOf(2903);
|
BigInteger p = BigInteger.valueOf(2903);
|
||||||
BigInteger q = p.subtract(BigInteger.ONE).divide(BigInteger.valueOf(2));
|
BigInteger q = p.subtract(BigInteger.ONE).divide(BigInteger.valueOf(2));
|
||||||
|
Zpstar zpstar = new Zpstar(p);
|
||||||
|
random = new Random();
|
||||||
|
BigInteger g;
|
||||||
|
BigInteger ZERO = zpstar.zero();
|
||||||
|
do{
|
||||||
|
g = zpstar.sample(random);
|
||||||
|
}while (!g.equals(ZERO) && !zpstar.multiply(g,q).equals(ZERO));// sample from QRZp*
|
||||||
int t = 8;
|
int t = 8;
|
||||||
int n = 20;
|
int n = 20;
|
||||||
random = new Random();
|
|
||||||
BigInteger g = null; //Todo
|
|
||||||
verifiableSecretSharingArray = new VerifiableSecretSharing[tests];
|
verifiableSecretSharingArray = new VerifiableSecretSharing[tests];
|
||||||
for (int i = 0; i < verifiableSecretSharingArray.length; i++){
|
for (int i = 0; i < verifiableSecretSharingArray.length; i++){
|
||||||
verifiableSecretSharingArray[i] = new VerifiableSecretSharing(t,n
|
verifiableSecretSharingArray[i] = new VerifiableSecretSharing(t,n
|
||||||
|
@ -38,8 +41,7 @@ public class VerifiableSecretSharingTest {
|
||||||
|
|
||||||
public void oneTest(VerifiableSecretSharing verifiableSecretSharing) throws Exception {
|
public void oneTest(VerifiableSecretSharing verifiableSecretSharing) throws Exception {
|
||||||
int n = verifiableSecretSharing.getN();
|
int n = verifiableSecretSharing.getN();
|
||||||
BigInteger p = verifiableSecretSharing.getQ();
|
Zpstar zpstar = verifiableSecretSharing.getZpstar();
|
||||||
Zpstar zpstar = new Zpstar(p);
|
|
||||||
BigInteger g = verifiableSecretSharing.getGenerator();
|
BigInteger g = verifiableSecretSharing.getGenerator();
|
||||||
Polynomial.Point[] shares = new Polynomial.Point[n];
|
Polynomial.Point[] shares = new Polynomial.Point[n];
|
||||||
BigInteger[] commitments = verifiableSecretSharing.getCommitments();
|
BigInteger[] commitments = verifiableSecretSharing.getCommitments();
|
||||||
|
@ -56,7 +58,7 @@ public class VerifiableSecretSharingTest {
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
//@Test
|
@Test
|
||||||
public void secretSharingTest() throws Exception {
|
public void secretSharingTest() throws Exception {
|
||||||
for (int i = 0 ; i < verifiableSecretSharingArray.length; i ++){
|
for (int i = 0 ; i < verifiableSecretSharingArray.length; i ++){
|
||||||
oneTest(verifiableSecretSharingArray[i]);
|
oneTest(verifiableSecretSharingArray[i]);
|
||||||
|
|
Loading…
Reference in New Issue