added some JavaDoc comments and documentation

vbdev2
Hai Brenner 2016-07-04 11:54:36 +03:00
parent 7db6218735
commit 2b56928e9a
12 changed files with 90 additions and 34 deletions

View File

@ -69,7 +69,7 @@ public class SimpleListCategoriesSelector implements QuestionSelector {
assertDataValid(); assertDataValid();
} }
/* /**
* asserts that the selection data does not contain a question index which is beyond the length of * asserts that the selection data does not contain a question index which is beyond the length of
* the ballot race questions array. Otherwise, throws an IndexOutOfBoundsException * the ballot race questions array. Otherwise, throws an IndexOutOfBoundsException
*/ */
@ -130,9 +130,11 @@ public class SimpleListCategoriesSelector implements QuestionSelector {
return isSelected; return isSelected;
} }
/* /**
* Verifies that the ballot answer is of length 1. (We do not yet handle multi-choice questions in the channel choice round). * Verifies that the ballot answer is of length 1. (We do not yet handle multi-choice questions in the channel choice round).
* Otherwise, throws an exception. * Otherwise, throws an exception.
* @param ballotAnswer
* @param questionNumber the number of the question (needed only for error message strings)
*/ */
private void assertAnswerLengthIsOne (BallotAnswer ballotAnswer, int questionNumber) { private void assertAnswerLengthIsOne (BallotAnswer ballotAnswer, int questionNumber) {
if (ballotAnswer.getAnswerCount() != 1) { if (ballotAnswer.getAnswerCount() != 1) {
@ -157,8 +159,10 @@ public class SimpleListCategoriesSelector implements QuestionSelector {
return selectedQuestions; return selectedQuestions;
} }
/* /**
* copies a List of Integers into an int[] array of same length * copies a List of Integers into an int[] array of same length
* @param l a list of Integers
* @return an array of ints
*/ */
private int[] listToIntArray(List<Integer> l) { private int[] listToIntArray(List<Integer> l) {
int[] res = new int[l.size()]; int[] res = new int[l.size()];

View File

@ -7,6 +7,7 @@ import java.security.SignatureException;
/** /**
* An interface for the encryptor component of the voting booth * An interface for the encryptor component of the voting booth
* It handles both the encryption and the digital signature
*/ */
public interface VBCryptoManager { public interface VBCryptoManager {
/** /**

View File

@ -11,13 +11,13 @@ import java.security.SignatureException;
import java.util.Random; import java.util.Random;
/** /**
* Created by hai on 07/06/16. * A basic implementation of the VBCryptoManager interface
*/ */
public class VBCryptoManagerImpl implements VBCryptoManager { public class VBCryptoManagerImpl implements VBCryptoManager {
protected final static Logger logger = LoggerFactory.getLogger(VBCryptoManagerImpl.class); protected final static Logger logger = LoggerFactory.getLogger(VBCryptoManagerImpl.class);
private final Random random; private final Random random; //TODO: Random object should be more cryptographycally secure
private final Encryption encryption; private final Encryption encryption;
private final DigitalSignature digitalSignature; private final DigitalSignature digitalSignature;

View File

@ -12,7 +12,9 @@ import org.slf4j.LoggerFactory;
import java.util.concurrent.LinkedBlockingQueue; import java.util.concurrent.LinkedBlockingQueue;
/** /**
* Created by hai on 27/06/16. * This is a base class for simple OutputDevices which run asynchronously (as a separate thread).
* The methods of the BallotOutputDevice simply register a matching OutputCommand in the instance's queue
* The Runnable.run method simply takes the next registered command and calls the matching (abstract) method
*/ */
public abstract class AsyncRunnableOutputDevice implements BallotOutputDevice, Runnable { public abstract class AsyncRunnableOutputDevice implements BallotOutputDevice, Runnable {
@ -52,16 +54,10 @@ public abstract class AsyncRunnableOutputDevice implements BallotOutputDevice, R
queue.clear(); queue.clear();
} }
/**
abstract void doCommitToBallot(CommitOutputCommand command); * chooses the next method to run according to the type of the given OutputCommand
* @param command any valid OutputCommand
abstract void doAudit(AuditOutputCommand command); */
abstract void doCastBallot(CastOutputCommand command);
abstract void doCancel(CancelOutputCommand command);
private void handleSingleCommand(OutputCommand command) { private void handleSingleCommand(OutputCommand command) {
if (command instanceof CommitOutputCommand) { if (command instanceof CommitOutputCommand) {
doCommitToBallot((CommitOutputCommand)command); doCommitToBallot((CommitOutputCommand)command);
@ -111,4 +107,28 @@ public abstract class AsyncRunnableOutputDevice implements BallotOutputDevice, R
} }
/**
* This method should be filled by an extending class. It should have the details of how to commit to a ballot
* @param command
*/
abstract void doCommitToBallot(CommitOutputCommand command);
/**
* This method should be filled by an extending class. It should have the details of how to audit the ballot
* @param command
*/
abstract void doAudit(AuditOutputCommand command);
/**
* This method should be filled by an extending class. It should have the details of how to cast the ballot
* @param command
*/
abstract void doCastBallot(CastOutputCommand command);
/**
* This method should be filled by an extending class. It should have the details of how to cancel the ballot output
* @param command
*/
abstract void doCancel(CancelOutputCommand command);
} }

View File

@ -20,7 +20,7 @@ public interface BallotOutputDevice {
/** /**
* Voter chose 'audit'. Output the ballot secrets to prove correctness of the encryption. * Voter chose 'audit'. Output the ballot secrets to prove correctness of the encryption.
* @param ballotSecrets - the secrtes of the encryption * @param ballotSecrets - the secrets of the encryption
* @param callback - a callback object which expects no return value * @param callback - a callback object which expects no return value
*/ */
public void audit(BallotSecrets ballotSecrets, FutureCallback<Void> callback); public void audit(BallotSecrets ballotSecrets, FutureCallback<Void> callback);
@ -37,5 +37,8 @@ public interface BallotOutputDevice {
*/ */
public void cancelBallot(FutureCallback<Void> callback); public void cancelBallot(FutureCallback<Void> callback);
/**
* A method for shutting down the Output Device
*/
public void callShutDown(); public void callShutDown();
} }

View File

@ -20,20 +20,17 @@ import java.io.IOException;
import static meerkat.pollingstation.PollingStationConstants.POLLING_STATION_WEB_SCANNER_SCAN_PATH; import static meerkat.pollingstation.PollingStationConstants.POLLING_STATION_WEB_SCANNER_SCAN_PATH;
/** /**
* Created by hai on 27/06/16. * A ballot output device for the network. It simply sends details over the wire
*/ */
public class NetworkVirtualPrinter extends AsyncRunnableOutputDevice { public class NetworkVirtualPrinter extends AsyncRunnableOutputDevice {
private Logger logger; private static final Logger logger = LoggerFactory.getLogger(NetworkVirtualPrinter.class);
private SignedEncryptedBallot signedEncryptedBallot; private SignedEncryptedBallot signedEncryptedBallot;
private final WebTarget successfulPrintTarget; private final WebTarget successfulPrintTarget;
public NetworkVirtualPrinter(String address) { public NetworkVirtualPrinter(String address) {
super(); super();
logger = LoggerFactory.getLogger(NetworkVirtualPrinter.class);
logger.info("A NetworkVirtualPrinter is constructed"); logger.info("A NetworkVirtualPrinter is constructed");
Client client = ClientBuilder.newClient(); Client client = ClientBuilder.newClient();
client.register(ProtobufMessageBodyReader.class); client.register(ProtobufMessageBodyReader.class);
client.register(ProtobufMessageBodyWriter.class); client.register(ProtobufMessageBodyWriter.class);
@ -41,6 +38,12 @@ public class NetworkVirtualPrinter extends AsyncRunnableOutputDevice {
} }
/**
* The NetworkVirtualPrinter actually does nothing for committing.
* It simply keeps the ballot details for later.
* When the voter chooses to Cast the ballot, these details are sent over the wire.
* @param command a CommitOutputCommand with the signed encryption of the ballot
*/
public void doCommitToBallot(CommitOutputCommand command) { public void doCommitToBallot(CommitOutputCommand command) {
logger.debug("entered method doCommitToBallot"); logger.debug("entered method doCommitToBallot");
signedEncryptedBallot = command.getSignedEncryptedBallot(); signedEncryptedBallot = command.getSignedEncryptedBallot();
@ -48,6 +51,9 @@ public class NetworkVirtualPrinter extends AsyncRunnableOutputDevice {
} }
/**
* The NetworkVirtualPrinter actually does nothing for auditing.
*/
public void doAudit(AuditOutputCommand command) { public void doAudit(AuditOutputCommand command) {
logger.debug("entered method doAudit"); logger.debug("entered method doAudit");
signedEncryptedBallot = null; signedEncryptedBallot = null;
@ -55,6 +61,10 @@ public class NetworkVirtualPrinter extends AsyncRunnableOutputDevice {
} }
/**
* This is where the magic happens. The signed encrypted ballot is transmitted over the wire
* @param command
*/
public void doCastBallot(CastOutputCommand command) { public void doCastBallot(CastOutputCommand command) {
logger.debug("entered method doCastBallot"); logger.debug("entered method doCastBallot");
ScannedData scannedData = ScannedData.newBuilder() ScannedData scannedData = ScannedData.newBuilder()
@ -75,6 +85,9 @@ public class NetworkVirtualPrinter extends AsyncRunnableOutputDevice {
} }
/**
* The NetworkVirtualPrinter actually does nothing for canceling.
*/
public void doCancel(CancelOutputCommand command) { public void doCancel(CancelOutputCommand command) {
logger.debug("entered method doCancel"); logger.debug("entered method doCancel");
signedEncryptedBallot = null; signedEncryptedBallot = null;

View File

@ -13,17 +13,18 @@ import org.slf4j.LoggerFactory;
*/ */
public class SystemConsoleOutputDevice extends AsyncRunnableOutputDevice { public class SystemConsoleOutputDevice extends AsyncRunnableOutputDevice {
private Logger logger; private static final Logger logger = LoggerFactory.getLogger(SystemConsoleOutputDevice.class);;
public SystemConsoleOutputDevice () { public SystemConsoleOutputDevice () {
super(); super();
logger = LoggerFactory.getLogger(SystemConsoleOutputDevice.class);
logger.info("A SystemConsoleOutputDevice is constructed"); logger.info("A SystemConsoleOutputDevice is constructed");
} }
/**
* Committing to the ballot.
* Simply prints to the output stream all the details in the CommitOutputCommand.
* @param command details to commit to, and the callback to call when finished
*/
public void doCommitToBallot(CommitOutputCommand command) { public void doCommitToBallot(CommitOutputCommand command) {
logger.debug("entered method doCommitToBallot"); logger.debug("entered method doCommitToBallot");
PlaintextBallot plaintextBallot = command.getPlaintext(); PlaintextBallot plaintextBallot = command.getPlaintext();
@ -43,16 +44,24 @@ public class SystemConsoleOutputDevice extends AsyncRunnableOutputDevice {
} }
/**
* auditing the ballot.
* prints to the output stream the ballot secrets (the encryption randomness and its proof of random generation)
* @param command An auditing command with the callback to finally call
*/
public void doAudit(AuditOutputCommand command) { public void doAudit(AuditOutputCommand command) {
logger.debug("entered method doAudit"); logger.debug("entered method doAudit");
System.out.println("Auditing"); System.out.println("Auditing");
BallotSecrets ballotSecrets = command.getBallotSecrets(); BallotSecrets ballotSecrets = command.getBallotSecrets();
printEncryptionRandomness (ballotSecrets.getEncryptionRandomness()); printEncryptionRandomness(ballotSecrets.getEncryptionRandomness());
printRandomnessGenerationProof (ballotSecrets.getProof()); printRandomnessGenerationProof (ballotSecrets.getProof());
command.getCallback().onSuccess(null); command.getCallback().onSuccess(null);
} }
/**
* Casting the ballot (actually does nothing new)
* @param command
*/
public void doCastBallot(CastOutputCommand command) { public void doCastBallot(CastOutputCommand command) {
logger.debug("entered method doCastBallot"); logger.debug("entered method doCastBallot");
System.out.println("Ballot finalized for casting!"); System.out.println("Ballot finalized for casting!");
@ -60,6 +69,10 @@ public class SystemConsoleOutputDevice extends AsyncRunnableOutputDevice {
} }
/**
* Canceling the ballot (actually does nothing new)
* @param command
*/
public void doCancel(CancelOutputCommand command) { public void doCancel(CancelOutputCommand command) {
logger.debug("entered method doCancel"); logger.debug("entered method doCancel");
System.out.println("Ballot cancelled!"); System.out.println("Ballot cancelled!");

View File

@ -4,7 +4,7 @@ import meerkat.protobuf.Voting.*;
import meerkat.voting.controller.callbacks.ControllerCallback; import meerkat.voting.controller.callbacks.ControllerCallback;
/** /**
* Created by hai on 15/06/16. * This OutputCommand supplies the necessary details for outputting Audit information
*/ */
public class AuditOutputCommand extends OutputCommand { public class AuditOutputCommand extends OutputCommand {

View File

@ -3,7 +3,7 @@ package meerkat.voting.output.outputcommands;
import meerkat.voting.controller.callbacks.ControllerCallback; import meerkat.voting.controller.callbacks.ControllerCallback;
/** /**
* Created by hai on 15/06/16. * This OutputCommand signals the output-device that it should Cancel the rest of the ballot output
*/ */
public class CancelOutputCommand extends OutputCommand { public class CancelOutputCommand extends OutputCommand {

View File

@ -3,7 +3,7 @@ package meerkat.voting.output.outputcommands;
import meerkat.voting.controller.callbacks.ControllerCallback; import meerkat.voting.controller.callbacks.ControllerCallback;
/** /**
* Created by hai on 15/06/16. * This OutputCommand signals the output-device that the voter wishes to Cast the ballot
*/ */
public class CastOutputCommand extends OutputCommand { public class CastOutputCommand extends OutputCommand {

View File

@ -4,7 +4,7 @@ import meerkat.protobuf.Voting.*;
import meerkat.voting.controller.callbacks.ControllerCallback; import meerkat.voting.controller.callbacks.ControllerCallback;
/** /**
* Created by hai on 15/06/16. * This OutputCommand supplies the necessary details for outputting a commit to the ballot
*/ */
public class CommitOutputCommand extends OutputCommand { public class CommitOutputCommand extends OutputCommand {

View File

@ -2,7 +2,9 @@ package meerkat.voting.output.outputcommands;
import meerkat.voting.controller.callbacks.ControllerCallback; import meerkat.voting.controller.callbacks.ControllerCallback;
//TODO: make this class generic /**
* Base class for the commands to put in the output-device queue
*/
public abstract class OutputCommand { public abstract class OutputCommand {
protected final ControllerCallback callback; protected final ControllerCallback callback;