From 6100497e8e0f5f55a88197022ace85ac2ca75488 Mon Sep 17 00:00:00 2001 From: "tzlil.gon" Date: Wed, 27 Jan 2016 13:41:24 +0200 Subject: [PATCH] Feldman's VSS --- destributed-key-generation/build.gradle | 220 ++++++++++++++++++ .../VerifiableSecretSharing.java | 54 +++++ .../java/ShamirSecretSharing/Polynomial.java | 119 ++++++++++ .../ShamirSecretSharing/SecretSharing.java | 56 +++++ gradle/wrapper/gradle-wrapper.jar | Bin 52271 -> 53636 bytes gradle/wrapper/gradle-wrapper.properties | 5 +- gradlew | 10 +- .../crypto/concrete/ECElGamalEncryption.java | 2 +- settings.gradle | 1 + 9 files changed, 456 insertions(+), 11 deletions(-) create mode 100644 destributed-key-generation/build.gradle create mode 100644 destributed-key-generation/src/main/java/FeldmanVerifiableSecretSharing/VerifiableSecretSharing.java create mode 100644 destributed-key-generation/src/main/java/ShamirSecretSharing/Polynomial.java create mode 100644 destributed-key-generation/src/main/java/ShamirSecretSharing/SecretSharing.java diff --git a/destributed-key-generation/build.gradle b/destributed-key-generation/build.gradle new file mode 100644 index 0000000..60ec7c9 --- /dev/null +++ b/destributed-key-generation/build.gradle @@ -0,0 +1,220 @@ + +plugins { + id "us.kirchmeier.capsule" version "1.0.1" + id 'com.google.protobuf' version '0.7.0' +} + +apply plugin: 'java' +apply plugin: 'eclipse' +apply plugin: 'idea' + +apply plugin: 'maven-publish' + +// Uncomment the lines below to define an application +// (this will also allow you to build a "fatCapsule" which includes +// the entire application, including all dependencies in a single jar) +//apply plugin: 'application' +//mainClassName='your.main.ApplicationClass' + +// Is this a snapshot version? +ext { isSnapshot = false } + +ext { + groupId = 'org.factcenter.meerkat' + nexusRepository = "https://cs.idc.ac.il/nexus/content/groups/${isSnapshot ? 'unstable' : 'public'}/" + + // Credentials for IDC nexus repositories (needed only for using unstable repositories and publishing) + // Should be set in ${HOME}/.gradle/gradle.properties + nexusUser = project.hasProperty('nexusUser') ? project.property('nexusUser') : "" + nexusPassword = project.hasProperty('nexusPassword') ? project.property('nexusPassword') : "" +} + +description = "TODO: Add a description" + +// Your project version +version = "0.0" + +version += "${isSnapshot ? '-SNAPSHOT' : ''}" + + +dependencies { + // Meerkat common + compile project(':meerkat-common') + + // Logging + compile 'org.slf4j:slf4j-api:1.7.7' + runtime 'ch.qos.logback:logback-classic:1.1.2' + runtime 'ch.qos.logback:logback-core:1.1.2' + + // Google protobufs + compile 'com.google.protobuf:protobuf-java:3.+' + + testCompile 'junit:junit:4.+' + + runtime 'org.codehaus.groovy:groovy:2.4.+' +} + + +/*==== You probably don't have to edit below this line =======*/ + +// Setup test configuration that can appear as a dependency in +// other subprojects +configurations { + testOutput.extendsFrom (testCompile) +} + +task testJar(type: Jar, dependsOn: testClasses) { + classifier = 'tests' + from sourceSets.test.output +} + +artifacts { + testOutput testJar +} + +// The run task added by the application plugin +// is also of type JavaExec. +tasks.withType(JavaExec) { + // Assign all Java system properties from + // the command line to the JavaExec task. + systemProperties System.properties +} + + +protobuf { + // Configure the protoc executable + protoc { + // Download from repositories + artifact = 'com.google.protobuf:protoc:3.+' + } +} + + +idea { + module { + project.sourceSets.each { sourceSet -> + + def srcDir = "${protobuf.generatedFilesBaseDir}/$sourceSet.name/java" + + println "Adding $srcDir" + // add protobuf generated sources to generated source dir. + if ("test".equals(sourceSet.name)) { + testSourceDirs += file(srcDir) + } else { + sourceDirs += file(srcDir) + } + generatedSourceDirs += file(srcDir) + + } + + // Don't exclude build directory + excludeDirs -= file(buildDir) + } +} + + +/*=================================== + * "Fat" Build targets + *===================================*/ + + +if (project.hasProperty('mainClassName') && (mainClassName != null)) { + + task mavenCapsule(type: MavenCapsule) { + description = "Generate a capsule jar that automatically downloads and caches dependencies when run." + applicationClass mainClassName + destinationDir = buildDir + } + + task fatCapsule(type: FatCapsule) { + description = "Generate a single capsule jar containing everything. Use -Pfatmain=... to override main class" + + destinationDir = buildDir + + def fatMain = hasProperty('fatmain') ? fatmain : mainClassName + + applicationClass fatMain + + def testJar = hasProperty('test') + + if (hasProperty('fatmain')) { + appendix = "fat-${fatMain}" + } else { + appendix = "fat" + } + + if (testJar) { + from sourceSets.test.output + } + } +} + + +/*=================================== + * Repositories + *===================================*/ + +repositories { + + // Prefer the local nexus repository (it may have 3rd party artifacts not found in mavenCentral) + maven { + url nexusRepository + + if (isSnapshot) { + credentials { username + password + + username nexusUser + password nexusPassword + } + } + } + + // Use local maven repository + mavenLocal() + + // Use 'maven central' for other dependencies. + mavenCentral() +} + +task "info" << { + println "Project: ${project.name}" +println "Description: ${project.description}" + println "--------------------------" + println "GroupId: $groupId" + println "Version: $version (${isSnapshot ? 'snapshot' : 'release'})" + println "" +} +info.description 'Print some information about project parameters' + + +/*=================================== + * Publishing + *===================================*/ + +publishing { + publications { + mavenJava(MavenPublication) { + groupId project.groupId + pom.withXml { + asNode().appendNode('description', project.description) + } + from project.components.java + + } + } + repositories { + maven { + url "https://cs.idc.ac.il/nexus/content/repositories/${project.isSnapshot ? 'snapshots' : 'releases'}" + credentials { username + password + + username nexusUser + password nexusPassword + } + } + } +} + + + diff --git a/destributed-key-generation/src/main/java/FeldmanVerifiableSecretSharing/VerifiableSecretSharing.java b/destributed-key-generation/src/main/java/FeldmanVerifiableSecretSharing/VerifiableSecretSharing.java new file mode 100644 index 0000000..fea7a1b --- /dev/null +++ b/destributed-key-generation/src/main/java/FeldmanVerifiableSecretSharing/VerifiableSecretSharing.java @@ -0,0 +1,54 @@ +package FeldmanVerifiableSecretSharing; + +import ShamirSecretSharing.SecretSharing; +import org.bouncycastle.util.Arrays; +import org.factcenter.qilin.primitives.concrete.Zpstar; + +import java.math.BigInteger; +import java.util.Random; + +/** + * Created by Tzlil on 1/27/2016. + */ +public class VerifiableSecretSharing extends SecretSharing { + + private final BigInteger[] commitments; + private final BigInteger g; + + public VerifiableSecretSharing(Zpstar zpstar, int t, int n, BigInteger s, Random random) { + super(zpstar, t, n, s, random); + this.g = BigInteger.ONE; //ToDO zpstar.getGenerator() + this.commitments = generateCommitments(); + } + + private BigInteger[] generateCommitments() { + BigInteger[] coefficients = polynomial.getCoefficients(); + BigInteger[] commitments = new BigInteger[coefficients.length]; + for (int i = 0 ; i < commitments.length;i++){ + commitments[i] = zpstar.multiply(g,coefficients[i]); + } + return commitments; + } + + public BigInteger verify(int i) throws Exception { + if(i < 1 || i > n){ + throw new Exception(); + } + BigInteger v = BigInteger.ONE; + int power = 1; + for (int j = 0 ; j < commitments.length ; j ++){ + v.multiply(commitments[i].pow(power)); + power *=i; + } + return zpstar.add(BigInteger.ONE,v); + } + + + public BigInteger getG() { + return g; + } + + public BigInteger[] getCommitments() { + return Arrays.clone(commitments); + } +} diff --git a/destributed-key-generation/src/main/java/ShamirSecretSharing/Polynomial.java b/destributed-key-generation/src/main/java/ShamirSecretSharing/Polynomial.java new file mode 100644 index 0000000..69b4da5 --- /dev/null +++ b/destributed-key-generation/src/main/java/ShamirSecretSharing/Polynomial.java @@ -0,0 +1,119 @@ +package ShamirSecretSharing; + +import org.bouncycastle.util.Arrays; +import org.factcenter.qilin.primitives.concrete.ECGroup; + +import java.math.BigInteger; + +/** + * Created by Tzlil on 1/27/2016. + */ +public class Polynomial { + + private static final Polynomial ZERO = new Polynomial(new BigInteger[]{BigInteger.ZERO}); + private static final Polynomial ONE = new Polynomial(new BigInteger[]{BigInteger.ONE}); + private final int degree; + private final BigInteger[] coefficients; + + public Polynomial(BigInteger[] coefficients) { + this.degree = coefficients.length - 1; + this.coefficients = coefficients; + } + + public Polynomial(Polynomial polynomial) { + this.degree = polynomial.getDegree(); + this.coefficients = polynomial.getCoefficients(); + } + + public BigInteger image(BigInteger x){ + BigInteger result = BigInteger.ZERO; + BigInteger power = BigInteger.ONE; + for(int i = 0 ; i <= degree ; i++){ + result.add(coefficients[i].multiply(power)); + power.multiply(x); + } + return result; + } + + public static Polynomial interpolation(Point[] points){ + Polynomial[] factors = new Polynomial[points.length]; + for (int i = 0 ; i < factors.length ; i++){ + factors[i] = new Polynomial(new BigInteger[]{BigInteger.ONE,points[i].x}); // X - Xi + } + Polynomial result = ZERO; + BigInteger constant; + Polynomial product; + for (int i = 0 ; i < points.length; i++){ + constant = points[i].y; + product = ONE; + for (int j = 0 ; j < points.length; j ++){ + if(i != j ) { + constant = constant.divide(points[i].x.subtract(points[j].x)); + product = product.mul(factors[j]); + } + } + result.add(product.mul(constant)); + } + return result; + } + + public Polynomial add(Polynomial other){ + Polynomial bigger,smaller; + if(this.degree < other.degree){ + bigger = other; + smaller = this; + }else{ + bigger = this; + smaller = other; + } + BigInteger[] coefficients = bigger.getCoefficients(); + + for (int i = 0; i <= smaller.degree ; i++){ + coefficients[i] = smaller.coefficients[i].add(bigger.coefficients[i]); + } + return new Polynomial(coefficients); + } + + public Polynomial mul(BigInteger constant){ + + BigInteger[] coefficients = this.getCoefficients(); + + for (int i = 0; i <= this.degree ; i++){ + coefficients[i] = constant.multiply(coefficients[i]); + } + return new Polynomial(coefficients); + } + + public Polynomial mul(Polynomial other){ + + BigInteger[] coefficients = new BigInteger[this.degree + other.degree + 1]; + java.util.Arrays.fill(coefficients,BigInteger.ZERO); + + for (int i = 0; i <= this.degree ; i++){ + for (int j = 0; j <= other.degree; j++){ + coefficients[i+j] = coefficients[i+j].add(this.coefficients[i].multiply(other.coefficients[j])); + } + } + return new Polynomial(coefficients); + } + + + public BigInteger[] getCoefficients() { + return Arrays.clone(coefficients); + } + public int getDegree() { + return degree; + } + + + public static class Point{ + public final BigInteger x; + public final BigInteger y; + + public Point(BigInteger x, BigInteger y) { + this.x = x; + this.y = y; + } + } + +} diff --git a/destributed-key-generation/src/main/java/ShamirSecretSharing/SecretSharing.java b/destributed-key-generation/src/main/java/ShamirSecretSharing/SecretSharing.java new file mode 100644 index 0000000..4457f95 --- /dev/null +++ b/destributed-key-generation/src/main/java/ShamirSecretSharing/SecretSharing.java @@ -0,0 +1,56 @@ +package ShamirSecretSharing; + + +import org.factcenter.qilin.primitives.concrete.Zpstar; + +import java.math.BigInteger; +import java.util.Random; + +/** + * Created by Tzlil on 1/27/2016. + */ +public class SecretSharing { + protected final Zpstar zpstar; + protected final int t; + protected final int n; + protected final Polynomial polynomial; + + public SecretSharing(Zpstar zpstar, int t, int n, BigInteger s, Random random) { + this.zpstar = zpstar; + this.t = t; + this.n = n; + this.polynomial = generateRandomPolynomial(s,random); + } + + private Polynomial generateRandomPolynomial(BigInteger s, Random random) { + BigInteger[] coefficients = new BigInteger[t + 1]; + coefficients[0] = s; + for (int i = 1 ; i <= t; i++ ){ + coefficients[i] = zpstar.sample(random); + } + return new Polynomial(coefficients); + } + + //ToDo make it safe : permission to call this func + modulo calc + public Polynomial.Point getShare(int i) throws Exception { + if(i < 1 || i > n){ + throw new Exception(); + } + return new Polynomial.Point(BigInteger.valueOf(i), polynomial.image(BigInteger.valueOf(i))); + } + + public static BigInteger getSecrete(Polynomial.Point[] shares){ + Polynomial polynomial = Polynomial.interpolation(shares); + return polynomial.image(BigInteger.ZERO); + } + + public int getThreshold() { + return t; + } + + public int getN() { + return n; + } + + +} diff --git a/gradle/wrapper/gradle-wrapper.jar b/gradle/wrapper/gradle-wrapper.jar index 30d399d8d2bf522ff5de94bf434a7cc43a9a74b5..941144813d241db74e1bf25b6804c679fbe7f0a3 100644 GIT binary patch delta 12486 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 E0L*8@(*OVf delta 11073 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 diff --git a/gradle/wrapper/gradle-wrapper.properties b/gradle/wrapper/gradle-wrapper.properties index 864f396..1360c1c 100644 --- a/gradle/wrapper/gradle-wrapper.properties +++ b/gradle/wrapper/gradle-wrapper.properties @@ -1,7 +1,6 @@ -#Tue Aug 05 03:26:05 IDT 2014 +#Wed Jan 27 00:30:26 IST 2016 distributionBase=GRADLE_USER_HOME distributionPath=wrapper/dists zipStoreBase=GRADLE_USER_HOME zipStorePath=wrapper/dists -distributionUrl=https\://services.gradle.org/distributions/gradle-2.9-all.zip -distributionSha256Sum=4647967f8de78d6d6d8093cdac50f368f8c2b8038f41a5afe1c3bce4c69219a9 +distributionUrl=https\://services.gradle.org/distributions/gradle-2.9-bin.zip diff --git a/gradlew b/gradlew index 91a7e26..9d82f78 100755 --- a/gradlew +++ b/gradlew @@ -42,11 +42,6 @@ case "`uname`" in ;; esac -# For Cygwin, ensure paths are in UNIX format before anything is touched. -if $cygwin ; then - [ -n "$JAVA_HOME" ] && JAVA_HOME=`cygpath --unix "$JAVA_HOME"` -fi - # Attempt to set APP_HOME # Resolve links: $0 may be a link PRG="$0" @@ -61,9 +56,9 @@ while [ -h "$PRG" ] ; do fi done SAVED="`pwd`" -cd "`dirname \"$PRG\"`/" >&- +cd "`dirname \"$PRG\"`/" >/dev/null APP_HOME="`pwd -P`" -cd "$SAVED" >&- +cd "$SAVED" >/dev/null CLASSPATH=$APP_HOME/gradle/wrapper/gradle-wrapper.jar @@ -114,6 +109,7 @@ fi if $cygwin ; then APP_HOME=`cygpath --path --mixed "$APP_HOME"` CLASSPATH=`cygpath --path --mixed "$CLASSPATH"` + JAVACMD=`cygpath --unix "$JAVACMD"` # We build the pattern for arguments to be converted via cygpath ROOTDIRSRAW=`find -L / -maxdepth 1 -mindepth 1 -type d 2>/dev/null` diff --git a/meerkat-common/src/main/java/meerkat/crypto/concrete/ECElGamalEncryption.java b/meerkat-common/src/main/java/meerkat/crypto/concrete/ECElGamalEncryption.java index f9936c7..6258f5f 100644 --- a/meerkat-common/src/main/java/meerkat/crypto/concrete/ECElGamalEncryption.java +++ b/meerkat-common/src/main/java/meerkat/crypto/concrete/ECElGamalEncryption.java @@ -110,7 +110,7 @@ public class ECElGamalEncryption extends GlobalCryptoSetup implements Encryption Pair randomizer = elGamalPK.encrypt(curve.getInfinity(), rndInt); ConcreteCrypto.ElGamalCiphertext originalEncodedCipher= ConcreteCrypto.ElGamalCiphertext.parseFrom(msg.getData()); - Pair originalCipher = new Pair<>( + Pair originalCipher = new Pair( curve.decodePoint(originalEncodedCipher.getC1().toByteArray()), curve.decodePoint(originalEncodedCipher.getC2().toByteArray())); Pair newCipher = elGamalPK.add(originalCipher, randomizer); diff --git a/settings.gradle b/settings.gradle index 99f4c5e..5f81a65 100644 --- a/settings.gradle +++ b/settings.gradle @@ -4,4 +4,5 @@ include 'bulletin-board-server' include 'polling-station' include 'restful-api-common' include 'bulletin-board-client' +include 'destributed-key-generation'