Paillier Threshold Encryption WebService - PowerPoint PPT Presentation

1 / 10
About This Presentation
Title:

Paillier Threshold Encryption WebService

Description:

Paillier Threshold Encryption WebService by Brett Wilson – PowerPoint PPT presentation

Number of Views:79
Avg rating:3.0/5.0
Slides: 11
Provided by: Brett192
Learn more at: http://www.cs.uccs.edu
Category:

less

Transcript and Presenter's Notes

Title: Paillier Threshold Encryption WebService


1
Paillier Threshold Encryption WebService
  • by
  • Brett Wilson

2
Paillier Encryption
  • Trapdoor Discrete Logarithm Scheme
  • c gMrn mod n2
  • n is an RSA modulus
  • g is an integer of order na mod n2
  • r is a random number in Zn
  • M L(c?(n) mod n2)/L(g?(n) mod n2) mod n
  • L(u) (u-1)/n, ?(n)lcm((p-1)(q-1))
  • Important Properties
  • Homomorphic
  • E(M1 M2) E(M1) x E(M2), E(k x M) E(M)k
  • Self-blinding
  • Re-encryption with a different r doesnt change M

3
Threshold Encryption
  • Public key encryption as usual
  • Distribute secret key shares among i
    participants
  • Decryption can only be accomplished if a
    threshold number t of the i participants
    cooperate
  • No information about m can be obtained with less
    than t participants cooperating

4
Threshold Paillier Encryption
  • Different public key and secret key generation
    algorithm
  • Distribute secret key shares using Shamir Secret
    Sharing scheme
  • Sharing Decryption in the Context of Voting or
    Lotteries Fouque, Poupard, and Stern 2000

5
Threshold Paillier Encryption WebService
  • Key generation algorithm
  • Input
  • k size of key
  • l number of shares to generate
  • One RSA public key (of the designated
    participant) for each share
  • t threshold parameter
  • Output
  • Public Key PK
  • List SK1, , SKl of private key shares
  • Encrypted with supplied RSA keys so only
    designated participant can recover the key share
  • List of Verifier Keys VK, VK1, ,VKl

6
Threshold Paillier Encryption WebService
  • Encryption Algorithm
  • Input
  • Public Key PK
  • Random string r
  • Cleartext M
  • Output
  • Ciphertext c

7
Threshold Paillier Encryption WebService
  • Share Decryption Algorithm
  • Input
  • Ciphertext c
  • Private Key Share Ski
  • Encrypted with public key of webservice
  • Output
  • Decryption share ci
  • Validity proof pi

8
Threshold Paillier Encryption WebService
  • Combining Algorithm
  • Input
  • Ciphertext c
  • List of decryption shares c1,,cl
  • List of verification keys VK, VK1VKl
  • List of validity proofs P1,Pl
  • Output
  • M

9
Use of WebService in Secure Voting
  • Ballot format pick 1 out of c candidates
  • Vote 2clog2v where c is the desired candidate
    number (0c) and v is the next power of 2 greater
    than the maximum number of voters
  • All Paillier-encrypted votes could be publicly
    posted
  • At end of election, all encrypted votes could be
    multiplied together (publicly verifiable)
  • With cooperation of the required threshold number
    of authorities, the final product could be
    decrypted to reveal the vote total (sum of
    individual votes).
  • A threshold number of authorities would not agree
    to decrypt a single particular vote, and thus the
    individual votes would remain private
  • All computations are publicly verifiable given
    the validity proofs

10
Implementation Tools
  • Visual Studio 2005
  • VB.NET
  • Gnu Multiprecision Library (Gmp)
  • Open source arbitrary precision numeric library
  • Compiled under Visual Studio 2005
  • NGmp
  • Open source VB.NET binding of gmp.dll
  • Enables calling of gmp library functions through
    VB.NET
  • Compiled under Visual Studio 2005
Write a Comment
User Comments (0)
About PowerShow.com