mailman-lists-archive/pipermail/zapps-wg/2017/000012.html

438 lines
26 KiB
HTML

<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN">
<HTML>
<HEAD>
<TITLE> [zapps-wg] Powers of Tau Ceremony Proposal
</TITLE>
<LINK REL="Index" HREF="/pipermail/zapps-wg/2017/index.html" >
<LINK REL="made" HREF="mailto:zapps-wg%40lists.zfnd.org?Subject=Re%3A%20%5Bzapps-wg%5D%20Powers%20of%20Tau%20Ceremony%20Proposal&In-Reply-To=%3CCAKazn3krM1PqjgMOmn-9Koe4pVsh%3DWL-bMwb6U5hqi_s18-DSA%40mail.gmail.com%3E">
<META NAME="robots" CONTENT="index,nofollow">
<style type="text/css">
pre {
white-space: pre-wrap; /* css-2.1, curent FF, Opera, Safari */
}
</style>
<META http-equiv="Content-Type" content="text/html; charset=us-ascii">
<LINK REL="Previous" HREF="000011.html">
<LINK REL="Next" HREF="000013.html">
</HEAD>
<BODY BGCOLOR="#ffffff">
<H1>[zapps-wg] Powers of Tau Ceremony Proposal</H1>
<B>Sean Bowe</B>
<A HREF="mailto:zapps-wg%40lists.zfnd.org?Subject=Re%3A%20%5Bzapps-wg%5D%20Powers%20of%20Tau%20Ceremony%20Proposal&In-Reply-To=%3CCAKazn3krM1PqjgMOmn-9Koe4pVsh%3DWL-bMwb6U5hqi_s18-DSA%40mail.gmail.com%3E"
TITLE="[zapps-wg] Powers of Tau Ceremony Proposal">sean at z.cash
</A><BR>
<I>Sat Nov 11 14:01:24 EST 2017</I>
<P><UL>
<LI>Previous message (by thread): <A HREF="000011.html">[zapps-wg] Powers of Tau Ceremony Proposal
</A></li>
<LI>Next message (by thread): <A HREF="000013.html">[zapps-wg] Powers of Tau Ceremony Proposal
</A></li>
<LI> <B>Messages sorted by:</B>
<a href="date.html#12">[ date ]</a>
<a href="thread.html#12">[ thread ]</a>
<a href="subject.html#12">[ subject ]</a>
<a href="author.html#12">[ author ]</a>
</LI>
</UL>
<HR>
<!--beginarticle-->
<PRE>Kobi Gurkan (from QED-it) wishes to go after cody. I'll double-check later.
On Sat, Nov 11, 2017 at 4:12 AM, cody burns &lt;<A HREF="/mailman/listinfo/zapps-wg">cody.w.burns at gmail.com</A>&gt; wrote:
&gt;<i> I will go after the unnamed party.
</I>&gt;<i>
</I>&gt;<i>
</I>&gt;<i> On Sat, Nov 11, 2017 at 3:21 AM Sean Bowe via zapps-wg
</I>&gt;<i> &lt;<A HREF="/mailman/listinfo/zapps-wg">zapps-wg at lists.z.cash.foundation</A>&gt; wrote:
</I>&gt;&gt;<i>
</I>&gt;&gt;<i> All is verified and mirrored so far! Thanks!
</I>&gt;&gt;<i>
</I>&gt;&gt;<i> I've invited someone else to be next, but I'm not sure if they wanted
</I>&gt;&gt;<i> me to identify them publicly before they were finished.
</I>&gt;&gt;<i>
</I>&gt;&gt;<i> Sean
</I>&gt;&gt;<i>
</I>&gt;&gt;<i> On Fri, Nov 10, 2017 at 5:25 PM, Jason Davies &lt;<A HREF="/mailman/listinfo/zapps-wg">jason at jasondavies.com</A>&gt;
</I>&gt;&gt;<i> wrote:
</I>&gt;&gt;<i> &gt; Hi all,
</I>&gt;&gt;<i> &gt;
</I>&gt;&gt;<i> &gt; Here is my report:
</I>&gt;&gt;<i> &gt;
</I>&gt;&gt;<i> &gt; Powers of Tau Operational Writeup
</I>&gt;&gt;<i> &gt; =================================
</I>&gt;&gt;<i> &gt;
</I>&gt;&gt;<i> &gt; Round: 2
</I>&gt;&gt;<i> &gt; Date: 2017-11-10
</I>&gt;&gt;<i> &gt; Name: Jason Davies
</I>&gt;&gt;<i> &gt; Location: London, UK
</I>&gt;&gt;<i> &gt;
</I>&gt;&gt;<i> &gt; Challenge:
</I>&gt;&gt;<i> &gt; 467bc84f6eb98ff956eaf12a1b7ef4dc0aff1093c7a0d5c1dfbdb85bbfffb20a43965d0daefee3fec6c1a47af69100e117b44b74371824ac8af1e33b6f91add5
</I>&gt;&gt;<i> &gt; Response:
</I>&gt;&gt;<i> &gt; 2f728af894524f55bda7a3e2c2e2db6a57a992811e90ed57456d62aead5106cdc5c97c86532d14b5185cc74d169f1b0c2c0ef1e582231ffa7936da55047c0cb2
</I>&gt;&gt;<i> &gt;
</I>&gt;&gt;<i> &gt; Preparation Steps
</I>&gt;&gt;<i> &gt; =================
</I>&gt;&gt;<i> &gt;
</I>&gt;&gt;<i> &gt; Git repository: <A HREF="https://github.com/ebfull/powersoftau">https://github.com/ebfull/powersoftau</A>
</I>&gt;&gt;<i> &gt; Commit hash: 9e1553c437183540392a7231d0788318a19b18a3
</I>&gt;&gt;<i> &gt; Compiler: rustc 1.23.0-nightly (d6b06c63a 2017-11-09)
</I>&gt;&gt;<i> &gt; Build: cargo build --release --features=u128-support
</I>&gt;&gt;<i> &gt; b2sum(./target/release/compute):
</I>&gt;&gt;<i> &gt; be42f68b07c5c857bb6561a9ac2967d671ef412a71c87c2fb31776a6ab38c756736de66e554553021e129ecab45d922092873df8b71bd9a775ec05f189485198
</I>&gt;&gt;<i> &gt;
</I>&gt;&gt;<i> &gt; I used a brand new 16GB USB stick and loaded
</I>&gt;&gt;<i> &gt; ubuntu-17.04-desktop-amd64.iso; b2sum:
</I>&gt;&gt;<i> &gt; 6a1c975b25b4e7f2dbf4fda84fe8b5de3ed6f4532b8c4f17e533ed11a0a8b5b9ad9fb83e8e4b89447c3a427be73f77a5f7c71b7f733fcc4bebf346e9c5c0de43.
</I>&gt;&gt;<i> &gt;
</I>&gt;&gt;<i> &gt; I reformatted a second brand new 16GB USB stick to ext4, then copied the
</I>&gt;&gt;<i> &gt; `challenge` file and the `target/release/compute` binary.
</I>&gt;&gt;<i> &gt;
</I>&gt;&gt;<i> &gt; Sidechannel Defences
</I>&gt;&gt;<i> &gt; ====================
</I>&gt;&gt;<i> &gt;
</I>&gt;&gt;<i> &gt; First of all, I lined a large cardboard box with aluminium foil in order
</I>&gt;&gt;<i> &gt; to
</I>&gt;&gt;<i> &gt; make a rudimentary faraday cage. Then, I assembled an airgap compute
</I>&gt;&gt;<i> &gt; node
</I>&gt;&gt;<i> &gt; using some relatively cheap parts, putting them all inside the box:
</I>&gt;&gt;<i> &gt;
</I>&gt;&gt;<i> &gt; * Motherboard: Asus H81 Pro BTC (no radio, bluetooth or speakers AFAIK)
</I>&gt;&gt;<i> &gt; * CPU: Intel G1840
</I>&gt;&gt;<i> &gt; * Ram: 2x cheap 1GB sticks
</I>&gt;&gt;<i> &gt; * PSU: EVGA SuperNOVA 1300 G2
</I>&gt;&gt;<i> &gt; * Monitor: old Dell TFT display
</I>&gt;&gt;<i> &gt; * Keyboard: generic USB keyboard
</I>&gt;&gt;<i> &gt;
</I>&gt;&gt;<i> &gt; No other peripherals or cables were connected. I placed the compute
</I>&gt;&gt;<i> &gt; node in my
</I>&gt;&gt;<i> &gt; cellar (~6ft below ground level) and I remained with the node during the
</I>&gt;&gt;<i> &gt; entire
</I>&gt;&gt;<i> &gt; time it was computing, without using any other devices in the vicinity
</I>&gt;&gt;<i> &gt; (no
</I>&gt;&gt;<i> &gt; mobile phone etc.) The only cables coming out of the box were the two
</I>&gt;&gt;<i> &gt; power
</I>&gt;&gt;<i> &gt; cables, one for the PSU and one for the monitor.
</I>&gt;&gt;<i> &gt;
</I>&gt;&gt;<i> &gt; Image: <A HREF="https://pbs.twimg.com/media/DOT55KUXUAEV44-.jpg:large">https://pbs.twimg.com/media/DOT55KUXUAEV44-.jpg:large</A>
</I>&gt;&gt;<i> &gt;
</I>&gt;&gt;<i> &gt; Procedure
</I>&gt;&gt;<i> &gt; =========
</I>&gt;&gt;<i> &gt;
</I>&gt;&gt;<i> &gt; I booted the node, with &quot;Try Ubuntu&quot; (Live CD mode). Then, I inserted
</I>&gt;&gt;<i> &gt; the
</I>&gt;&gt;<i> &gt; challenge USB stick and ran `./compute` in the USB media directory,
</I>&gt;&gt;<i> &gt; entering
</I>&gt;&gt;<i> &gt; some additional entropy as requested by typing randomly on the keyboard.
</I>&gt;&gt;<i> &gt; The
</I>&gt;&gt;<i> &gt; box lid was only partially opened to allow use of the keyboard and to
</I>&gt;&gt;<i> &gt; view the
</I>&gt;&gt;<i> &gt; monitor at this point. After 60 minutes had passed, I looked inside the
</I>&gt;&gt;<i> &gt; lid
</I>&gt;&gt;<i> &gt; and saw that the computation had completed, so I wrote down the BLAKE2b
</I>&gt;&gt;<i> &gt; hash,
</I>&gt;&gt;<i> &gt; and unmounted and removed the USB stick, and then powered the node down.
</I>&gt;&gt;<i> &gt;
</I>&gt;&gt;<i> &gt; Postprocessing
</I>&gt;&gt;<i> &gt; ==============
</I>&gt;&gt;<i> &gt;
</I>&gt;&gt;<i> &gt; I took the USB stick and transferred the response file to my laptop, and
</I>&gt;&gt;<i> &gt; then
</I>&gt;&gt;<i> &gt; uploaded it using the laptop to S3 via Sean Bowe's transcript site.
</I>&gt;&gt;<i> &gt;
</I>&gt;&gt;<i> &gt; I did not destroy the compute node but I'm unlikely to use it or plug it
</I>&gt;&gt;<i> &gt; in for
</I>&gt;&gt;<i> &gt; some time.
</I>&gt;&gt;<i> &gt; --
</I>&gt;&gt;<i> &gt; Jason Davies, <A HREF="https://www.jasondavies.com">https://www.jasondavies.com</A>
</I>&gt;&gt;<i> &gt;
</I>&gt;&gt;<i> &gt;
</I>&gt;&gt;<i> &gt;
</I>&gt;&gt;<i> &gt;
</I>&gt;&gt;<i> &gt;&gt; On 10 Nov 2017, at 22:11, Sean Bowe via zapps-wg
</I>&gt;&gt;<i> &gt;&gt; &lt;<A HREF="/mailman/listinfo/zapps-wg">zapps-wg at lists.z.cash.foundation</A>&gt; wrote:
</I>&gt;&gt;<i> &gt;&gt;
</I>&gt;&gt;<i> &gt;&gt; Thanks Andrew! That's a great start.
</I>&gt;&gt;<i> &gt;&gt;
</I>&gt;&gt;<i> &gt;&gt; Now it's Jason Davies' turn.
</I>&gt;&gt;<i> &gt;&gt;
</I>&gt;&gt;<i> &gt;&gt; The entire transcript will appear here throughout the process:
</I>&gt;&gt;<i> &gt;&gt;
</I>&gt;&gt;<i> &gt;&gt; <A HREF="https://powersoftau-transcript.s3-us-west-2.amazonaws.com/index.html">https://powersoftau-transcript.s3-us-west-2.amazonaws.com/index.html</A>
</I>&gt;&gt;<i> &gt;&gt;
</I>&gt;&gt;<i> &gt;&gt; We can make a more formal announcement once we're in the groove and
</I>&gt;&gt;<i> &gt;&gt; everything looks good. We're getting a repo up with attestations soon
</I>&gt;&gt;<i> &gt;&gt; also.
</I>&gt;&gt;<i> &gt;&gt;
</I>&gt;&gt;<i> &gt;&gt; Sean
</I>&gt;&gt;<i> &gt;&gt;
</I>&gt;&gt;<i> &gt;&gt; On Fri, Nov 10, 2017 at 12:53 PM, Andrew Miller &lt;<A HREF="/mailman/listinfo/zapps-wg">soc1024 at illinois.edu</A>&gt;
</I>&gt;&gt;<i> &gt;&gt; wrote:
</I>&gt;&gt;<i> &gt;&gt;&gt; OK, I'll go first. Below is my report:
</I>&gt;&gt;<i> &gt;&gt;&gt;
</I>&gt;&gt;<i> &gt;&gt;&gt; Powers of Tau Operational writeup
</I>&gt;&gt;<i> &gt;&gt;&gt; =================================
</I>&gt;&gt;<i> &gt;&gt;&gt; Round: 1
</I>&gt;&gt;<i> &gt;&gt;&gt; Date: 2011-11-10
</I>&gt;&gt;<i> &gt;&gt;&gt; Name: Andrew Miller
</I>&gt;&gt;<i> &gt;&gt;&gt; Location: Champaign, Illinois
</I>&gt;&gt;<i> &gt;&gt;&gt;
</I>&gt;&gt;<i> &gt;&gt;&gt; Challenge: (genesis)
</I>&gt;&gt;<i> &gt;&gt;&gt;
</I>&gt;&gt;<i> &gt;&gt;&gt; ce00f2100dd876fdff8dd824f55307bcb72d724f29ff20b9e0760f3a65e5588a65eaed57cbc61697111ae1f4cc7da2e62a85311c2ae683a041fb872b891c68dc
</I>&gt;&gt;<i> &gt;&gt;&gt; Response:
</I>&gt;&gt;<i> &gt;&gt;&gt;
</I>&gt;&gt;<i> &gt;&gt;&gt; 15729e0edc4201dc5ee6241437d926f614cb4214ff1b9c6fbd73daf401639f7a4238cf04bc94edac9f2ad037003daab9a4408ba7c62a4413dc2a0ddd683bd719
</I>&gt;&gt;<i> &gt;&gt;&gt; ./response-2017-11-10-amiller
</I>&gt;&gt;<i> &gt;&gt;&gt;
</I>&gt;&gt;<i> &gt;&gt;&gt; Preparation steps
</I>&gt;&gt;<i> &gt;&gt;&gt; =================
</I>&gt;&gt;<i> &gt;&gt;&gt; I used Sean&#8217;s powersoftau rust repo, commit
</I>&gt;&gt;<i> &gt;&gt;&gt; 9e1553c437183540392a7231d0788318a19b18a3
</I>&gt;&gt;<i> &gt;&gt;&gt;
</I>&gt;&gt;<i> &gt;&gt;&gt; I followed instructions online for building portable rust binaries,
</I>&gt;&gt;<i> &gt;&gt;&gt; and so I ran
</I>&gt;&gt;<i> &gt;&gt;&gt; ```
</I>&gt;&gt;<i> &gt;&gt;&gt; cargo build --target=x86_64-unknown-linux-musl --release
</I>&gt;&gt;<i> &gt;&gt;&gt; --features=u128-support --bin=compute
</I>&gt;&gt;<i> &gt;&gt;&gt; ```
</I>&gt;&gt;<i> &gt;&gt;&gt;
</I>&gt;&gt;<i> &gt;&gt;&gt; Compiler: rustc 1.23.0-nightly (02004ef78 2017-11-08)
</I>&gt;&gt;<i> &gt;&gt;&gt;
</I>&gt;&gt;<i> &gt;&gt;&gt; I copied the resulting binary to a freshly formatted USB stick I had.
</I>&gt;&gt;<i> &gt;&gt;&gt;
</I>&gt;&gt;<i> &gt;&gt;&gt; b2sum:
</I>&gt;&gt;<i> &gt;&gt;&gt;
</I>&gt;&gt;<i> &gt;&gt;&gt; 9059a0a64f5021c36df630ca48ac40674862b2fea14f4843ff2150256b95162ac4d6d1621d2dd3f5d0d1c604ad8e581c0ff449d2449140380eab075a9b83c960
</I>&gt;&gt;<i> &gt;&gt;&gt; ./target/x86_64-unknown-linux-musl/release/compute
</I>&gt;&gt;<i> &gt;&gt;&gt;
</I>&gt;&gt;<i> &gt;&gt;&gt; I also rummaged through my shelf of several USB sticks, and found one
</I>&gt;&gt;<i> &gt;&gt;&gt; that happened to be a Linux Mint 18 USB bootable disk, so I used that
</I>&gt;&gt;<i> &gt;&gt;&gt; for my operating system.
</I>&gt;&gt;<i> &gt;&gt;&gt;
</I>&gt;&gt;<i> &gt;&gt;&gt; Sidechannel defenses
</I>&gt;&gt;<i> &gt;&gt;&gt; ====================
</I>&gt;&gt;<i> &gt;&gt;&gt; I used an airgap compute node, a Dell Inspiron that I&#8217;ve had for about
</I>&gt;&gt;<i> &gt;&gt;&gt; a year now (Actually this is a computer I bought last year for
</I>&gt;&gt;<i> &gt;&gt;&gt; dress-rehearsals in the Zcash Sprout param generation ceremony).
</I>&gt;&gt;<i> &gt;&gt;&gt;
</I>&gt;&gt;<i> &gt;&gt;&gt; I unplugged all the computer&#8217;s hard drives, and detached its
</I>&gt;&gt;<i> &gt;&gt;&gt; wifi/bluetooth radios. I booted the computer from the Linux Mint
</I>&gt;&gt;<i> &gt;&gt;&gt; livecd usb stick, and then also copied the binaries into RAM. The
</I>&gt;&gt;<i> &gt;&gt;&gt; compute node was located in my bedroom, and I attended it for the ~1hr
</I>&gt;&gt;<i> &gt;&gt;&gt; duration of the compute process.
</I>&gt;&gt;<i> &gt;&gt;&gt;
</I>&gt;&gt;<i> &gt;&gt;&gt; Image: <A HREF="https://pbs.twimg.com/media/DOSZz4FXkAEKC7N.jpg:large">https://pbs.twimg.com/media/DOSZz4FXkAEKC7N.jpg:large</A>
</I>&gt;&gt;<i> &gt;&gt;&gt;
</I>&gt;&gt;<i> &gt;&gt;&gt; Postprocessing
</I>&gt;&gt;<i> &gt;&gt;&gt; ==============
</I>&gt;&gt;<i> &gt;&gt;&gt; After compute was finished, I took a cell phone picture of the blake2b
</I>&gt;&gt;<i> &gt;&gt;&gt; hash of the response. I then copied the response file to the USB stick
</I>&gt;&gt;<i> &gt;&gt;&gt; containing the binaries, and then I unplugged the compute node. Using
</I>&gt;&gt;<i> &gt;&gt;&gt; my personal laptop, I posted the blake2b hash to the #mpc chat and
</I>&gt;&gt;<i> &gt;&gt;&gt; uploaded the response file to s3.
</I>&gt;&gt;<i> &gt;&gt;&gt;
</I>&gt;&gt;<i> &gt;&gt;&gt; The repsonse file is hosted here for now, though I expect we'll
</I>&gt;&gt;<i> &gt;&gt;&gt; mirror it elsewhere later:
</I>&gt;&gt;<i> &gt;&gt;&gt; <A HREF="https://s3.amazonaws.com/socrates1024_a/response-2017-11-10-amiller">https://s3.amazonaws.com/socrates1024_a/response-2017-11-10-amiller</A>
</I>&gt;&gt;<i> &gt;&gt;&gt;
</I>&gt;&gt;<i> &gt;&gt;&gt; I did not destroy the compute node and do plan to use it again,
</I>&gt;&gt;<i> &gt;&gt;&gt; although I'm going to leave it unplugged for several days.
</I>&gt;&gt;<i> &gt;&gt;&gt;
</I>&gt;&gt;<i> &gt;&gt;&gt; On Wed, Nov 8, 2017 at 10:19 PM, Sean Bowe &lt;<A HREF="/mailman/listinfo/zapps-wg">sean at z.cash</A>&gt; wrote:
</I>&gt;&gt;<i> &gt;&gt;&gt;&gt; Note that the `response` file contains a hash of the `challenge` file
</I>&gt;&gt;<i> &gt;&gt;&gt;&gt; that was used as input for the compute tool. As a result, only the
</I>&gt;&gt;<i> &gt;&gt;&gt;&gt; hashes of the `response` files need to be published; a hash chain is
</I>&gt;&gt;<i> &gt;&gt;&gt;&gt; formed through all participants. The initial challenge file is
</I>&gt;&gt;<i> &gt;&gt;&gt;&gt; deterministic. (You can use the `new` tool on the repository to
</I>&gt;&gt;<i> &gt;&gt;&gt;&gt; construct it.)
</I>&gt;&gt;<i> &gt;&gt;&gt;&gt;
</I>&gt;&gt;<i> &gt;&gt;&gt;&gt; The initial challenge file has BLAKE2b hash:
</I>&gt;&gt;<i> &gt;&gt;&gt;&gt;
</I>&gt;&gt;<i> &gt;&gt;&gt;&gt;
</I>&gt;&gt;<i> &gt;&gt;&gt;&gt; ce00f2100dd876fdff8dd824f55307bcb72d724f29ff20b9e0760f3a65e5588a65eaed57cbc61697111ae1f4cc7da2e62a85311c2ae683a041fb872b891c68dc
</I>&gt;&gt;<i> &gt;&gt;&gt;&gt;
</I>&gt;&gt;<i> &gt;&gt;&gt;&gt; It doesn't hurt to post hashes of everything though. Hash all the
</I>&gt;&gt;<i> &gt;&gt;&gt;&gt; things.
</I>&gt;&gt;<i> &gt;&gt;&gt;&gt;
</I>&gt;&gt;<i> &gt;&gt;&gt;&gt; Sean
</I>&gt;&gt;<i> &gt;&gt;&gt;&gt;
</I>&gt;&gt;<i> &gt;&gt;&gt;&gt; On Wed, Nov 8, 2017 at 4:51 PM, Andrew Miller &lt;<A HREF="/mailman/listinfo/zapps-wg">soc1024 at illinois.edu</A>&gt;
</I>&gt;&gt;<i> &gt;&gt;&gt;&gt; wrote:
</I>&gt;&gt;<i> &gt;&gt;&gt;&gt;&gt; Thanks Sean!
</I>&gt;&gt;<i> &gt;&gt;&gt;&gt;&gt;
</I>&gt;&gt;<i> &gt;&gt;&gt;&gt;&gt; My idea is to use an ad hoc and publicly visible process. &quot;Get in
</I>&gt;&gt;<i> &gt;&gt;&gt;&gt;&gt; contact with [sean]&quot; could be as simple as posting in public to this
</I>&gt;&gt;<i> &gt;&gt;&gt;&gt;&gt; thread. Unless we're overrun by trolls, a public mailing list can be
</I>&gt;&gt;<i> &gt;&gt;&gt;&gt;&gt; an informal way to agree on who goes next. Whoever posts and says
</I>&gt;&gt;<i> &gt;&gt;&gt;&gt;&gt; &quot;Me,
</I>&gt;&gt;<i> &gt;&gt;&gt;&gt;&gt; me! I'd like to go next&quot;, should, by convention, go next. Any
</I>&gt;&gt;<i> &gt;&gt;&gt;&gt;&gt; aberrations (parties taking too long or dropping out, posting
</I>&gt;&gt;<i> &gt;&gt;&gt;&gt;&gt; invalid
</I>&gt;&gt;<i> &gt;&gt;&gt;&gt;&gt; data, etc., can be dealt with as needed).
</I>&gt;&gt;<i> &gt;&gt;&gt;&gt;&gt;
</I>&gt;&gt;<i> &gt;&gt;&gt;&gt;&gt; I believe it's also the case that
</I>&gt;&gt;<i> &gt;&gt;&gt;&gt;&gt; a) The &quot;response&quot; file from each person is roughly the same as the
</I>&gt;&gt;<i> &gt;&gt;&gt;&gt;&gt; &quot;challenge&quot; file for the next participant, and
</I>&gt;&gt;<i> &gt;&gt;&gt;&gt;&gt; b) The response/challenge files are safe to be published at any
</I>&gt;&gt;<i> &gt;&gt;&gt;&gt;&gt; time,
</I>&gt;&gt;<i> &gt;&gt;&gt;&gt;&gt; not private at all.
</I>&gt;&gt;<i> &gt;&gt;&gt;&gt;&gt; So, by convention, we should post the hashes of those files here
</I>&gt;&gt;<i> &gt;&gt;&gt;&gt;&gt; right
</I>&gt;&gt;<i> &gt;&gt;&gt;&gt;&gt; away, and make a best effort to mirror them publicly (each one is
</I>&gt;&gt;<i> &gt;&gt;&gt;&gt;&gt; like
</I>&gt;&gt;<i> &gt;&gt;&gt;&gt;&gt; a gigabyte, I think).
</I>&gt;&gt;<i> &gt;&gt;&gt;&gt;&gt;
</I>&gt;&gt;<i> &gt;&gt;&gt;&gt;&gt; What does the initial challenge file consist of? Could you post the
</I>&gt;&gt;<i> &gt;&gt;&gt;&gt;&gt; hash of it here?
</I>&gt;&gt;<i> &gt;&gt;&gt;&gt;&gt;
</I>&gt;&gt;<i> &gt;&gt;&gt;&gt;&gt; Cheers,
</I>&gt;&gt;<i> &gt;&gt;&gt;&gt;&gt;
</I>&gt;&gt;<i> &gt;&gt;&gt;&gt;&gt; On Wed, Nov 8, 2017 at 3:04 PM, Sean Bowe via zapps-wg
</I>&gt;&gt;<i> &gt;&gt;&gt;&gt;&gt; &lt;<A HREF="/mailman/listinfo/zapps-wg">zapps-wg at lists.z.cash.foundation</A>&gt; wrote:
</I>&gt;&gt;<i> &gt;&gt;&gt;&gt;&gt;&gt; Ariel Gabizon, Ian Miers and I have just published a new paper
</I>&gt;&gt;<i> &gt;&gt;&gt;&gt;&gt;&gt; detailing a
</I>&gt;&gt;<i> &gt;&gt;&gt;&gt;&gt;&gt; multi-party computation (MPC) protocol for constructing zk-SNARK
</I>&gt;&gt;<i> &gt;&gt;&gt;&gt;&gt;&gt; public
</I>&gt;&gt;<i> &gt;&gt;&gt;&gt;&gt;&gt; parameters.
</I>&gt;&gt;<i> &gt;&gt;&gt;&gt;&gt;&gt;
</I>&gt;&gt;<i> &gt;&gt;&gt;&gt;&gt;&gt; <A HREF="https://eprint.iacr.org/2017/1050">https://eprint.iacr.org/2017/1050</A>
</I>&gt;&gt;<i> &gt;&gt;&gt;&gt;&gt;&gt;
</I>&gt;&gt;<i> &gt;&gt;&gt;&gt;&gt;&gt; The highlights are:
</I>&gt;&gt;<i> &gt;&gt;&gt;&gt;&gt;&gt;
</I>&gt;&gt;<i> &gt;&gt;&gt;&gt;&gt;&gt; * It allows for a single, gigantic ceremony to take place for all
</I>&gt;&gt;<i> &gt;&gt;&gt;&gt;&gt;&gt; possible
</I>&gt;&gt;<i> &gt;&gt;&gt;&gt;&gt;&gt; zk-SNARK circuits within a given size bound. The results of this
</I>&gt;&gt;<i> &gt;&gt;&gt;&gt;&gt;&gt; ceremony
</I>&gt;&gt;<i> &gt;&gt;&gt;&gt;&gt;&gt; are partial zk-SNARK parameters for the entire community. We call
</I>&gt;&gt;<i> &gt;&gt;&gt;&gt;&gt;&gt; this
</I>&gt;&gt;<i> &gt;&gt;&gt;&gt;&gt;&gt; communal ceremony the Powers of Tau.
</I>&gt;&gt;<i> &gt;&gt;&gt;&gt;&gt;&gt; * If you want to use zk-SNARKs in your protocols, you still have to
</I>&gt;&gt;<i> &gt;&gt;&gt;&gt;&gt;&gt; do an
</I>&gt;&gt;<i> &gt;&gt;&gt;&gt;&gt;&gt; MPC for your circuit. But because of the Powers of Tau ceremony,
</I>&gt;&gt;<i> &gt;&gt;&gt;&gt;&gt;&gt; your
</I>&gt;&gt;<i> &gt;&gt;&gt;&gt;&gt;&gt; ceremony is much cheaper to perform and the costs per-participant
</I>&gt;&gt;<i> &gt;&gt;&gt;&gt;&gt;&gt; scale
</I>&gt;&gt;<i> &gt;&gt;&gt;&gt;&gt;&gt; linearly with respect to the circuit complexity.
</I>&gt;&gt;<i> &gt;&gt;&gt;&gt;&gt;&gt; * The best part is that the Powers of Tau and these
</I>&gt;&gt;<i> &gt;&gt;&gt;&gt;&gt;&gt; circuit-specific MPCs
</I>&gt;&gt;<i> &gt;&gt;&gt;&gt;&gt;&gt; can scale to hundreds/thousands of participants. As the number of
</I>&gt;&gt;<i> &gt;&gt;&gt;&gt;&gt;&gt; participants grows, it becomes unrealistic that all of them could
</I>&gt;&gt;<i> &gt;&gt;&gt;&gt;&gt;&gt; be
</I>&gt;&gt;<i> &gt;&gt;&gt;&gt;&gt;&gt; compromised.
</I>&gt;&gt;<i> &gt;&gt;&gt;&gt;&gt;&gt;
</I>&gt;&gt;<i> &gt;&gt;&gt;&gt;&gt;&gt; So, let's do the Powers of Tau ceremony! The Zcash Foundation is
</I>&gt;&gt;<i> &gt;&gt;&gt;&gt;&gt;&gt; excited to
</I>&gt;&gt;<i> &gt;&gt;&gt;&gt;&gt;&gt; participate in the process. The Zcash Company is particularly
</I>&gt;&gt;<i> &gt;&gt;&gt;&gt;&gt;&gt; excited in
</I>&gt;&gt;<i> &gt;&gt;&gt;&gt;&gt;&gt; starting soon because we want to leverage it for our next MPC for
</I>&gt;&gt;<i> &gt;&gt;&gt;&gt;&gt;&gt; the
</I>&gt;&gt;<i> &gt;&gt;&gt;&gt;&gt;&gt; Sapling upgrade of Zcash.
</I>&gt;&gt;<i> &gt;&gt;&gt;&gt;&gt;&gt;
</I>&gt;&gt;<i> &gt;&gt;&gt;&gt;&gt;&gt; The MPC protocol for this ceremony only requires that one
</I>&gt;&gt;<i> &gt;&gt;&gt;&gt;&gt;&gt; participant
</I>&gt;&gt;<i> &gt;&gt;&gt;&gt;&gt;&gt; successfully destroy the secret randomness they sample during their
</I>&gt;&gt;<i> &gt;&gt;&gt;&gt;&gt;&gt; part. We
</I>&gt;&gt;<i> &gt;&gt;&gt;&gt;&gt;&gt; intend to give participants total flexibility in deciding how to
</I>&gt;&gt;<i> &gt;&gt;&gt;&gt;&gt;&gt; participate; we don't mind what software, hardware or OS you use.
</I>&gt;&gt;<i> &gt;&gt;&gt;&gt;&gt;&gt;
</I>&gt;&gt;<i> &gt;&gt;&gt;&gt;&gt;&gt; I have written some Rust software for participants to run:
</I>&gt;&gt;<i> &gt;&gt;&gt;&gt;&gt;&gt;
</I>&gt;&gt;<i> &gt;&gt;&gt;&gt;&gt;&gt; <A HREF="https://github.com/ebfull/powersoftau">https://github.com/ebfull/powersoftau</A>
</I>&gt;&gt;<i> &gt;&gt;&gt;&gt;&gt;&gt;
</I>&gt;&gt;<i> &gt;&gt;&gt;&gt;&gt;&gt; In order to simplify auditing, I won't be making any more changes
</I>&gt;&gt;<i> &gt;&gt;&gt;&gt;&gt;&gt; to the
</I>&gt;&gt;<i> &gt;&gt;&gt;&gt;&gt;&gt; code unless absolutely necessary. You don't have to use this
</I>&gt;&gt;<i> &gt;&gt;&gt;&gt;&gt;&gt; software, but
</I>&gt;&gt;<i> &gt;&gt;&gt;&gt;&gt;&gt; there are no alternative implementations at this time. I think it
</I>&gt;&gt;<i> &gt;&gt;&gt;&gt;&gt;&gt; should be
</I>&gt;&gt;<i> &gt;&gt;&gt;&gt;&gt;&gt; feasible to write a C version of the code using the RELIC toolkit,
</I>&gt;&gt;<i> &gt;&gt;&gt;&gt;&gt;&gt; which has
</I>&gt;&gt;<i> &gt;&gt;&gt;&gt;&gt;&gt; implemented BLS12-381. I am very confident in the Rust code,
</I>&gt;&gt;<i> &gt;&gt;&gt;&gt;&gt;&gt; though, and I
</I>&gt;&gt;<i> &gt;&gt;&gt;&gt;&gt;&gt; believe in its stability/correctness.
</I>&gt;&gt;<i> &gt;&gt;&gt;&gt;&gt;&gt;
</I>&gt;&gt;<i> &gt;&gt;&gt;&gt;&gt;&gt; I have some opinions about the ceremony:
</I>&gt;&gt;<i> &gt;&gt;&gt;&gt;&gt;&gt;
</I>&gt;&gt;<i> &gt;&gt;&gt;&gt;&gt;&gt; 1. I disagree with processes that don't improve security of the
</I>&gt;&gt;<i> &gt;&gt;&gt;&gt;&gt;&gt; ceremony.
</I>&gt;&gt;<i> &gt;&gt;&gt;&gt;&gt;&gt; Having a small surface area of code and process increases the
</I>&gt;&gt;<i> &gt;&gt;&gt;&gt;&gt;&gt; chance that
</I>&gt;&gt;<i> &gt;&gt;&gt;&gt;&gt;&gt; bugs will be discovered by auditors because there are fewer things
</I>&gt;&gt;<i> &gt;&gt;&gt;&gt;&gt;&gt; that can
</I>&gt;&gt;<i> &gt;&gt;&gt;&gt;&gt;&gt; go wrong. Remember that there is already quite a bit for the public
</I>&gt;&gt;<i> &gt;&gt;&gt;&gt;&gt;&gt; to
</I>&gt;&gt;<i> &gt;&gt;&gt;&gt;&gt;&gt; check: the transcript correctness, the code correctness, the
</I>&gt;&gt;<i> &gt;&gt;&gt;&gt;&gt;&gt; randomness
</I>&gt;&gt;<i> &gt;&gt;&gt;&gt;&gt;&gt; beacon, the cryptographic proof, code dependencies, etc.
</I>&gt;&gt;<i> &gt;&gt;&gt;&gt;&gt;&gt; 2. It needs to start soon so that it can be useful for the Sapling
</I>&gt;&gt;<i> &gt;&gt;&gt;&gt;&gt;&gt; MPC.
</I>&gt;&gt;<i> &gt;&gt;&gt;&gt;&gt;&gt; 3. It needs to have lots of reputable participants by the time we
</I>&gt;&gt;<i> &gt;&gt;&gt;&gt;&gt;&gt; start the
</I>&gt;&gt;<i> &gt;&gt;&gt;&gt;&gt;&gt; Sapling MPC.
</I>&gt;&gt;<i> &gt;&gt;&gt;&gt;&gt;&gt;
</I>&gt;&gt;<i> &gt;&gt;&gt;&gt;&gt;&gt; Given the above, I would like to suggest that we start the ceremony
</I>&gt;&gt;<i> &gt;&gt;&gt;&gt;&gt;&gt; now
</I>&gt;&gt;<i> &gt;&gt;&gt;&gt;&gt;&gt; using my existing code, which supports circuits up to 2^21 gates.
</I>&gt;&gt;<i> &gt;&gt;&gt;&gt;&gt;&gt; This means
</I>&gt;&gt;<i> &gt;&gt;&gt;&gt;&gt;&gt; people would just get in contact with me if they want to
</I>&gt;&gt;<i> &gt;&gt;&gt;&gt;&gt;&gt; participate and
</I>&gt;&gt;<i> &gt;&gt;&gt;&gt;&gt;&gt; I'll schedule them in. I'll try to prioritize reputable people, but
</I>&gt;&gt;<i> &gt;&gt;&gt;&gt;&gt;&gt; I'll
</I>&gt;&gt;<i> &gt;&gt;&gt;&gt;&gt;&gt; allow pretty much anyone I have time to. Everything that I do is
</I>&gt;&gt;<i> &gt;&gt;&gt;&gt;&gt;&gt; publicly
</I>&gt;&gt;<i> &gt;&gt;&gt;&gt;&gt;&gt; verifiable (there is a transcript at the end of the ceremony which
</I>&gt;&gt;<i> &gt;&gt;&gt;&gt;&gt;&gt; people
</I>&gt;&gt;<i> &gt;&gt;&gt;&gt;&gt;&gt; can check).
</I>&gt;&gt;<i> &gt;&gt;&gt;&gt;&gt;&gt;
</I>&gt;&gt;<i> &gt;&gt;&gt;&gt;&gt;&gt; Andrew Miller has a few interesting ideas for a more distributed
</I>&gt;&gt;<i> &gt;&gt;&gt;&gt;&gt;&gt; process for
</I>&gt;&gt;<i> &gt;&gt;&gt;&gt;&gt;&gt; scheduling &quot;who goes next&quot; but there are some disadvantages and
</I>&gt;&gt;<i> &gt;&gt;&gt;&gt;&gt;&gt; risks
</I>&gt;&gt;<i> &gt;&gt;&gt;&gt;&gt;&gt; involved IMO. In any case, the process can be changed later without
</I>&gt;&gt;<i> &gt;&gt;&gt;&gt;&gt;&gt; affecting anything, so I don't see a purpose in delaying the start
</I>&gt;&gt;<i> &gt;&gt;&gt;&gt;&gt;&gt; of the
</I>&gt;&gt;<i> &gt;&gt;&gt;&gt;&gt;&gt; ceremony on such things.
</I>&gt;&gt;<i> &gt;&gt;&gt;&gt;&gt;&gt;
</I>&gt;&gt;<i> &gt;&gt;&gt;&gt;&gt;&gt; I'd like to hear from others about this plan so we can begin soon!
</I>&gt;&gt;<i> &gt;&gt;&gt;&gt;&gt;&gt;
</I>&gt;&gt;<i> &gt;&gt;&gt;&gt;&gt;&gt; Sean Bowe
</I>&gt;&gt;<i> &gt;&gt;&gt;&gt;&gt;&gt; Zcash Company
</I>&gt;&gt;<i> &gt;&gt;&gt;&gt;&gt;
</I>&gt;&gt;<i> &gt;&gt;&gt;&gt;&gt;
</I>&gt;&gt;<i> &gt;&gt;&gt;&gt;&gt;
</I>&gt;&gt;<i> &gt;&gt;&gt;&gt;&gt; --
</I>&gt;&gt;<i> &gt;&gt;&gt;&gt;&gt; Andrew Miller
</I>&gt;&gt;<i> &gt;&gt;&gt;&gt;&gt; University of Illinois at Urbana-Champaign
</I>&gt;&gt;<i> &gt;&gt;&gt;
</I>&gt;&gt;<i> &gt;&gt;&gt;
</I>&gt;&gt;<i> &gt;&gt;&gt;
</I>&gt;&gt;<i> &gt;&gt;&gt; --
</I>&gt;&gt;<i> &gt;&gt;&gt; Andrew Miller
</I>&gt;&gt;<i> &gt;&gt;&gt; University of Illinois at Urbana-Champaign
</I>&gt;&gt;<i> &gt;
</I>&gt;&gt;<i> &gt;
</I>
</PRE>
<!--endarticle-->
<HR>
<P><UL>
<!--threads-->
<LI>Previous message (by thread): <A HREF="000011.html">[zapps-wg] Powers of Tau Ceremony Proposal
</A></li>
<LI>Next message (by thread): <A HREF="000013.html">[zapps-wg] Powers of Tau Ceremony Proposal
</A></li>
<LI> <B>Messages sorted by:</B>
<a href="date.html#12">[ date ]</a>
<a href="thread.html#12">[ thread ]</a>
<a href="subject.html#12">[ subject ]</a>
<a href="author.html#12">[ author ]</a>
</LI>
</UL>
<hr>
<a href="/mailman/listinfo/zapps-wg">More information about the zapps-wg
mailing list</a><br>
</body></html>