All Downloads are FREE. Search and download functionalities are using the official Maven repository.

dk.alexandra.fresco.lib.generic.BroadcastComputation Maven / Gradle / Ivy

There is a newer version: 1.3.7
Show newest version
package dk.alexandra.fresco.lib.generic;

import dk.alexandra.fresco.framework.DRes;
import dk.alexandra.fresco.framework.builder.Computation;
import dk.alexandra.fresco.framework.builder.ProtocolBuilderImpl;
import java.util.ArrayList;
import java.util.Collections;
import java.util.List;
import java.util.stream.Collectors;

/**
 * Generic active broadcast validation computation.
 *
 * 

Allows each party to securely broadcast a list of messages and receive the other parties' * messages.

* *

Uses generic native protocols {@link InsecureBroadcastProtocol} and {@link * BroadcastValidationProtocol}.

*/ public class BroadcastComputation> implements Computation, BuilderT> { private final List input; private final boolean runValidation; /** * Creates new {@link BroadcastComputation}. * * @param input list of messages this party will broadcast * @param runValidation indicates if messages received from other parties need to be validated for * consistency (this can be false for instance when there are only two parties participating in * the broadcast) */ public BroadcastComputation(List input, boolean runValidation) { this.input = input; this.runValidation = runValidation; } /** * Default constructor to {@link #BroadcastComputation(List, boolean)} for when a party only * broadcasts a single message. */ public BroadcastComputation(byte[] input, boolean runValidation) { this(Collections.singletonList(input), runValidation); } /** * Default constructor to {@link #BroadcastComputation(byte[], boolean)} for when a party only * broadcasts a single message and validation is required. */ public BroadcastComputation(byte[] input) { this(input, true); } @Override public DRes> buildComputation(BuilderT builder) { return builder.par(par -> { List>> broadcastValues = new ArrayList<>(); for (byte[] singleInput : input) { broadcastValues.add(par.append(new InsecureBroadcastProtocol<>(singleInput))); } return () -> broadcastValues; }).seq((seq, lst) -> { List toValidate = lst.stream() .flatMap(broadcast -> broadcast.out().stream()) .collect(Collectors.toList()); if (runValidation) { seq.append(new BroadcastValidationProtocol<>(toValidate)); } return () -> toValidate; }); } }




© 2015 - 2025 Weber Informatics LLC | Privacy Policy