Question 1 -
Consider the following protocol for two parties A and B to flip a fair coin.
1. A trusted party T publishes her public key pk;
2. Then A chooses a uniform bit bA, encrypts it using pk, an announces the ciphertext cA to B and T;
3. Next, B acts symmetrically and announces a ciphertext cB ≠ cA;
4. T decrypts both cA and cB, and the parties XOR the results to obtain the value of the coin.
- Argue that even if A is dishonest (but B is honest), the final value of the coin is uniformly distributed.
- Assume the parties use EI Gamal encryption (where the bit b is encoded as the group element gb before being encrypted - note that efficient decryption is still possible). Show how a dishonest B can bias the coin to any values he likes.
- Suggest what type of encryption scheme would be appropriate to use here. Can you define an appropriate notion of security for a fair coin flipping and prove that the above coin flipping protocol achieves this definition when using an appropriate encryption scheme?
Question 2 -
Suppose three users have RSA public keys (N1, 3), (N2, 3), and (N3, 3) (i.e., they all use e =3), with N1 < N2 < N3. Consider the following method for sending the same message m ∈ {0, 1}l to each of these parties: choose a uniform r ← Z∗N_1, and send to everyone the same ciphertext
< [r3 mod N1], [r3 mod N2], [r3 mod N3], H(r) ⊕ m > (1)
where H : Z∗N_1 → {0, 1}l. Assume l >> n
- Show that this is not CPA-secure, and an adversary can recover m from the ciphertext even when H is modeled as a random oracle.
- Show a simple way to fix this and get a CPA-secure method that transmits a ciphertext of length 3l + O(n).
Question 3 -
Secret sharing is a problem in cryptography where n shares X1, ..., Xn (called shadows) are given to n parties where some of the shadows or all of them are needed in order to reconstruct the secret (M) which is a number (i.e. there is a specified threshold t, such that any t shadows make it possible to compute M which is a bit string). Consider the following secret sharing algorithm:
1. Choose at random t-1 positive integers a1, ..., at-1 with ai < P (P is a prime number) and let a0 = M.
2. Build the polynomial f(x) = a0 + a1x + a2x2 + a3x3 + .... + at-1xt-1.
3. Create n shadows that are: (1, f(1)( mod p)), ...,(n, f(n)( mod p)) (i.e. every participant is given a point (an integer input to the polynomial, and the corresponding integer output).
Note: Suppose t < P - 1
Based on the above protocol, answer the following questions:
Part 1 - In above protocol, arithmetic is all modulo p to build the polynomial. Suppose that we mistakenly calculate the shadows as (x, f(x)) instead of (x, f(x)( mod p)), can an eavesdropper gain information from M or not if the eavesdropper sees some of the points (e.g. Suppose the eavesdropper finds (1,f(1)) or (2, f(2)))? If your answer is no, please prove it otherwise provide an example that shows the eavesdropper can gain information about M.
Part 2 - Suppose we modify the scheme such that M = a0 + a1 +. . .+ at-1 mod p. Does having t or more shadows make it possible to compute M? Does having fewer than t shadows reveal nothing about M? Please justify your answers.
Question 4 -
A strong one-time secure signature scheme satisfies the following: given a signature σ' on a message m', it is infeasible to output (m, σ) ≠ (m', σ') for which σ is a valid signature on m (note that m = m' is allowed)
- Give a formal definition of strong one-time secure signatures.
- Assuming the existence of one-way functions, show a one-way function for which Lamport's scheme is not a strong one-time secure signature scheme.
- Construct a strong one-time secure signature scheme based on any assumption use in the book.
Hint: Use a particular one-way function in Lamport's signature.