ignoring election params. dat files. Audit ballot QRcode.
							parent
							
								
									dadf301fcf
								
							
						
					
					
						commit
						ce2fe0e8f2
					
				|  | @ -36,3 +36,5 @@ testem.log | ||||||
| bundle.js | bundle.js | ||||||
| bundle.d.ts | bundle.d.ts | ||||||
| 
 | 
 | ||||||
|  | /voting-booth-gui/meerkat_election_params_tempfile.dat | ||||||
|  | /voting-booth-gui/meerkat_booth_system_messages.dat | ||||||
|  |  | ||||||
|  | @ -83,6 +83,11 @@ message BallotSecrets { | ||||||
|     RandomnessGenerationProof proof = 3; |     RandomnessGenerationProof proof = 3; | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
|  | message SignedBallotSecrets { | ||||||
|  |     BallotSecrets ballot_secrets = 1; | ||||||
|  |     Signature signature = 2; | ||||||
|  | } | ||||||
|  | 
 | ||||||
| message BoothParams { | message BoothParams { | ||||||
|     repeated SignatureVerificationKey pscVerificationKeys = 1; |     repeated SignatureVerificationKey pscVerificationKeys = 1; | ||||||
| 
 | 
 | ||||||
|  |  | ||||||
|  | @ -6,11 +6,9 @@ import com.google.zxing.WriterException; | ||||||
| import meerkat.protobuf.Crypto.EncryptionRandomness; | import meerkat.protobuf.Crypto.EncryptionRandomness; | ||||||
| import meerkat.protobuf.Crypto.RandomnessGenerationProof; | import meerkat.protobuf.Crypto.RandomnessGenerationProof; | ||||||
| import meerkat.protobuf.PollingStation; | import meerkat.protobuf.PollingStation; | ||||||
| import meerkat.protobuf.PollingStation.ScannedData; | import meerkat.protobuf.Voting; | ||||||
| import meerkat.protobuf.Voting.BallotSecrets; | import meerkat.protobuf.Voting.BallotSecrets; | ||||||
| import meerkat.protobuf.Voting.PlaintextBallot; | import meerkat.protobuf.Voting.PlaintextBallot; | ||||||
| import meerkat.protobuf.Voting.SignedEncryptedBallot; |  | ||||||
| import meerkat.rest.Constants; |  | ||||||
| import meerkat.voting.gui.controllersFX.VistaNavigator; | import meerkat.voting.gui.controllersFX.VistaNavigator; | ||||||
| import meerkat.voting.output.AsyncRunnableOutputDevice; | import meerkat.voting.output.AsyncRunnableOutputDevice; | ||||||
| import meerkat.voting.output.outputcommands.AuditOutputCommand; | import meerkat.voting.output.outputcommands.AuditOutputCommand; | ||||||
|  | @ -20,7 +18,6 @@ import meerkat.voting.output.outputcommands.CommitOutputCommand; | ||||||
| import org.slf4j.Logger; | import org.slf4j.Logger; | ||||||
| import org.slf4j.LoggerFactory; | import org.slf4j.LoggerFactory; | ||||||
| 
 | 
 | ||||||
| import javax.ws.rs.client.Entity; |  | ||||||
| import java.awt.image.BufferedImage; | import java.awt.image.BufferedImage; | ||||||
| import java.io.IOException; | import java.io.IOException; | ||||||
| import java.util.Base64; | import java.util.Base64; | ||||||
|  | @ -49,7 +46,7 @@ public class FXWindowOutputDevice extends AsyncRunnableOutputDevice { | ||||||
|         ByteString channel = command.getChannelIdentifierByteString(); |         ByteString channel = command.getChannelIdentifierByteString(); | ||||||
|         printPlainText(plaintextBallot, channel); |         printPlainText(plaintextBallot, channel); | ||||||
| 
 | 
 | ||||||
|         printEncryptedText(plaintextBallot, command); |         printCommitBallot(plaintextBallot, command); | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
| 
 | 
 | ||||||
|  | @ -61,11 +58,10 @@ public class FXWindowOutputDevice extends AsyncRunnableOutputDevice { | ||||||
|     public void doAudit(AuditOutputCommand command) { |     public void doAudit(AuditOutputCommand command) { | ||||||
|         logger.debug("entered method doAudit"); |         logger.debug("entered method doAudit"); | ||||||
|         VistaNavigator.printFXSeparator(); |         VistaNavigator.printFXSeparator(); | ||||||
|         String msg = "Auditing"; |  | ||||||
|         VistaNavigator.printFX(msg); |  | ||||||
|         BallotSecrets ballotSecrets = command.getBallotSecrets(); |         BallotSecrets ballotSecrets = command.getBallotSecrets(); | ||||||
|         printEncryptionRandomness(ballotSecrets.getEncryptionRandomness()); |         printEncryptionRandomness(ballotSecrets.getEncryptionRandomness()); | ||||||
|         printRandomnessGenerationProof (ballotSecrets.getProof()); |         printRandomnessGenerationProof (ballotSecrets.getProof()); | ||||||
|  |         printAuditBallot(ballotSecrets); | ||||||
|         command.getCallback().onSuccess(null); |         command.getCallback().onSuccess(null); | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
|  | @ -106,19 +102,15 @@ public class FXWindowOutputDevice extends AsyncRunnableOutputDevice { | ||||||
|         VistaNavigator.printFX(toPrint); |         VistaNavigator.printFX(toPrint); | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
|     private void printEncryptedText(PlaintextBallot plaintextBallot, CommitOutputCommand command) { |     private void printCommitBallot(PlaintextBallot plaintextBallot, CommitOutputCommand command) { | ||||||
|         String encryptedText; |  | ||||||
|         SignedEncryptedBallot signedEncryptedBallot = command.getSignedEncryptedBallot(); |  | ||||||
|         long encryptedSerialNumber = signedEncryptedBallot.getEncryptedBallot().getSerialNumber(); |  | ||||||
|         long plaintextSerialNumber = plaintextBallot.getSerialNumber(); |  | ||||||
| 
 |  | ||||||
|         String toPrint = ""; |         String toPrint = ""; | ||||||
|         toPrint+="Commitment of Ballot #" + encryptedSerialNumber + " (ciphertext):"; |         toPrint+="Commitment of Ballot #" + command.getSignedEncryptedBallot().getEncryptedBallot().getSerialNumber() + " (ciphertext):"; | ||||||
|         toPrint+="\n"; |         toPrint+="\n"; | ||||||
|         VistaNavigator.printFX(toPrint); |         VistaNavigator.printFX(toPrint); | ||||||
|         if (plaintextSerialNumber != encryptedSerialNumber) { | 
 | ||||||
|  |         if (plaintextBallot.getSerialNumber() != command.getSignedEncryptedBallot().getEncryptedBallot().getSerialNumber()) { | ||||||
|             logger.error("plaintext and encryption serial numbers do not match!! plaintext# = " + |             logger.error("plaintext and encryption serial numbers do not match!! plaintext# = " + | ||||||
|                     plaintextSerialNumber + ", ciphertext# = " + encryptedSerialNumber); |                     plaintextBallot.getSerialNumber() + ", ciphertext# = " + command.getSignedEncryptedBallot().getEncryptedBallot().getSerialNumber()); | ||||||
|         } |         } | ||||||
| 
 | 
 | ||||||
|         PollingStation.ScannedBallot scannedBallot = PollingStation.ScannedBallot.newBuilder() |         PollingStation.ScannedBallot scannedBallot = PollingStation.ScannedBallot.newBuilder() | ||||||
|  | @ -126,15 +118,15 @@ public class FXWindowOutputDevice extends AsyncRunnableOutputDevice { | ||||||
|                 .setSignedEncryptedBallot(command.getSignedEncryptedBallot()) |                 .setSignedEncryptedBallot(command.getSignedEncryptedBallot()) | ||||||
|                 .build(); |                 .build(); | ||||||
| 
 | 
 | ||||||
|         System.out.println(scannedBallot.getSerializedSize()); |         logger.info("ScannedBallot serialized size: "+scannedBallot.getSerializedSize()); | ||||||
|         encryptedText = Base64.getEncoder().encodeToString(scannedBallot.toByteArray()); |         String encryptedText = Base64.getEncoder().encodeToString(scannedBallot.toByteArray()); | ||||||
| 
 | 
 | ||||||
|         try { |         try { | ||||||
|             PollingStation.ScannedBallot result = PollingStation.ScannedBallot.parseFrom(Base64.getDecoder().decode(encryptedText.getBytes())); |             PollingStation.ScannedBallot result = PollingStation.ScannedBallot.parseFrom(Base64.getDecoder().decode(encryptedText.getBytes())); | ||||||
|             System.out.println(result.getChannel()); |             System.out.println(result.getChannel()); | ||||||
|             System.out.println(command.getChannelIdentifierByteString()); |             System.out.println(command.getChannelIdentifierByteString()); | ||||||
|         } catch (InvalidProtocolBufferException e) { |         } catch (InvalidProtocolBufferException e) { | ||||||
|             e.printStackTrace(); |             command.getCallback().onFailure(e); | ||||||
|         } |         } | ||||||
| 
 | 
 | ||||||
|         try { |         try { | ||||||
|  | @ -148,10 +140,41 @@ public class FXWindowOutputDevice extends AsyncRunnableOutputDevice { | ||||||
| 
 | 
 | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
|     private void printQRCode(String toQRCode, int size) throws IOException, WriterException { |     private void printAuditBallot(BallotSecrets ballotSecrets) { | ||||||
|         BufferedImage image = null; |         String toPrint = ""; | ||||||
|         image = GenerateQRCode.createQRImage(toQRCode, size); |         toPrint+="Audit of Ballot";// + command.getSignedEncryptedBallot().getEncryptedBallot().getSerialNumber() + " (ciphertext):";
 | ||||||
|         VistaNavigator.printFX(image); |         toPrint+="\n"; | ||||||
|  |         VistaNavigator.printFX(toPrint); | ||||||
|  | 
 | ||||||
|  |         //generate the PollingStation.<protobuf> corresponding to [plaintext, randomness, Signed(plaintext, randomness)]
 | ||||||
|  | //        PollingStation.ScannedBallot scannedBallot = PollingStation.ScannedBallot.newBuilder()
 | ||||||
|  | //                .setChannel(command.getChannelIdentifierByteString())
 | ||||||
|  | //                .setSignedEncryptedBallot(command.getSignedEncryptedBallot())
 | ||||||
|  | //                .build();
 | ||||||
|  | 
 | ||||||
|  |         //encode to String
 | ||||||
|  | //        logger.info("ScannedAudit serialized size: "+scannedBallot.getSerializedSize());
 | ||||||
|  | //        String auditText = Base64.getEncoder().encodeToString(scannedBallot.toByteArray());
 | ||||||
|  | 
 | ||||||
|  |         //check that decoding encoded gives same as original
 | ||||||
|  | //        try {
 | ||||||
|  | //            PollingStation.ScannedBallot result = PollingStation.ScannedBallot.parseFrom(Base64.getDecoder().decode(auditText.getBytes()));
 | ||||||
|  | //            System.out.println(result.getChannel());
 | ||||||
|  | //            System.out.println(command.getChannelIdentifierByteString());
 | ||||||
|  | //        } catch (InvalidProtocolBufferException e) {
 | ||||||
|  | //            command.getCallback().onFailure(e);
 | ||||||
|  | //        }
 | ||||||
|  | 
 | ||||||
|  |         //print to FX
 | ||||||
|  | //        try {
 | ||||||
|  | //            printQRCode(auditText, 250);
 | ||||||
|  | //            command.getCallback().onSuccess(null);
 | ||||||
|  | //        } catch (IOException e) {
 | ||||||
|  | //            command.getCallback().onFailure(e);
 | ||||||
|  | //        } catch (WriterException e) {
 | ||||||
|  | //            command.getCallback().onFailure(e);
 | ||||||
|  | //        }
 | ||||||
|  | 
 | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
|     private void printEncryptionRandomness (EncryptionRandomness encryptionRandomness) { |     private void printEncryptionRandomness (EncryptionRandomness encryptionRandomness) { | ||||||
|  | @ -168,6 +191,16 @@ public class FXWindowOutputDevice extends AsyncRunnableOutputDevice { | ||||||
|         VistaNavigator.printFX(msg); |         VistaNavigator.printFX(msg); | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
|  |     /** | ||||||
|  |      * Creates an image of the QRcode with the String toQRCode in it and displays it to the virtual printer (FX window) | ||||||
|  |      * @param toQRCode a String that contains the text to encode into the QRcode | ||||||
|  |      * @param size the size of the QRcode (we use 250 for testing) | ||||||
|  |      */ | ||||||
|  |     private void printQRCode(String toQRCode, int size) throws IOException, WriterException { | ||||||
|  |         BufferedImage image = null; | ||||||
|  |         image = GenerateQRCode.createQRImage(toQRCode, size); | ||||||
|  |         VistaNavigator.printFX(image); | ||||||
|  |     } | ||||||
| 
 | 
 | ||||||
|     /* |     /* | ||||||
|      * Returns the UTF8 decoding of byte-string data |      * Returns the UTF8 decoding of byte-string data | ||||||
|  |  | ||||||
|  | @ -40,5 +40,5 @@ public interface VBCryptoManager { | ||||||
|     // TODO: do we seed the random here?
 |     // TODO: do we seed the random here?
 | ||||||
|     public EncryptionAndSecrets encrypt (PlaintextBallot plaintextBallot) throws SignatureException, IOException; |     public EncryptionAndSecrets encrypt (PlaintextBallot plaintextBallot) throws SignatureException, IOException; | ||||||
| 
 | 
 | ||||||
| 
 |     //TODO: Laura: there should be a method here to sign whatever I need to sign, no? Does it mean that I need to create a class for each type of thing I need to sign?
 | ||||||
| } | } | ||||||
|  |  | ||||||
		Loading…
	
		Reference in New Issue