#feistel #byte #zcash #message #algorithm #encoded #encode

no-std f4jumble

Implementation of Zcash's F4Jumble algorithm

3 unstable releases

0.1.1 Dec 13, 2024
0.1.0 May 10, 2022
0.0.0 Sep 22, 2021

#461 in Magic Beans

Download history 1219/week @ 2024-09-14 2040/week @ 2024-09-21 2086/week @ 2024-09-28 1870/week @ 2024-10-05 1615/week @ 2024-10-12 1888/week @ 2024-10-19 1610/week @ 2024-10-26 1600/week @ 2024-11-02 2857/week @ 2024-11-09 3268/week @ 2024-11-16 2573/week @ 2024-11-23 3343/week @ 2024-11-30 3243/week @ 2024-12-07 2896/week @ 2024-12-14 1798/week @ 2024-12-21 1404/week @ 2024-12-28

10,030 downloads per month
Used in 49 crates (2 directly)

MIT/Apache

480KB
5K SLoC

f4jumble

An implementation of the F4Jumble algorithm, an unkeyed variable-width permutation.

F4Jumble is used by Zcash Unified Addresses and Unified Viewing Keys to prevent certain kinds of malleation attacks, and is specified by ZIP 316.

License

Licensed under either of

at your option.

Contribution

Unless you explicitly state otherwise, any contribution intentionally submitted for inclusion in the work by you, as defined in the Apache-2.0 license, shall be dual licensed as above, without any additional terms or conditions.


lib.rs:

This crate provides a mechanism for "jumbling" byte slices in a reversible way.

Many byte encodings such as Base64 and Bech32 do not have "cascading" behaviour: changing an input byte at one position has no effect on the encoding of bytes at distant positions. This can be a problem if users generally check the correctness of encoded strings by eye, as they will tend to only check the first and/or last few characters of the encoded string. In some situations (for example, a hardware device displaying on its screen an encoded string provided by an untrusted computer), it is potentially feasible for an adversary to change some internal portion of the encoded string in a way that is beneficial to them, without the user noticing.

The function F4Jumble (and its inverse function, F4Jumble⁻¹) are length-preserving transformations can be used to trivially introduce cascading behaviour to existing encodings:

  • Prepare the raw message bytes as usual.
  • Pass message through f4jumble or f4jumble_mut to obtain the jumbled bytes.
  • Encode the jumbled bytes with the encoding scheme.

Changing any byte of message will result in a completely different sequence of jumbled bytes. Specifically, F4Jumble uses an unkeyed 4-round Feistel construction to approximate a random permutation.

Diagram of 4-round unkeyed Feistel construction

Efficiency

The cost is dominated by 4 BLAKE2b compressions for message lengths up to 128 bytes. For longer messages, the cost increases to 6 BLAKE2b compressions for 128 < lₘ ≤ 192, and 10 BLAKE2b compressions for 192 < lₘ ≤ 256, for example. The maximum cost for which the algorithm is defined would be 196608 BLAKE2b compressions at lₘ = 4194368.

The implementations in this crate require memory of roughly lₘ bytes plus the size of a BLAKE2b hash state. It is possible to reduce this by (for example, with F4Jumble⁻¹) streaming the d part of the jumbled encoding three times from a less memory-constrained device. It is essential that the streamed value of d is the same on each pass, which can be verified using a Message Authentication Code (with key held only by the Consumer) or collision-resistant hash function. After the first pass of d, the implementation is able to compute y; after the second pass it is able to compute a; and the third allows it to compute and incrementally parse b. The maximum memory usage during this process would be 128 bytes plus two BLAKE2b hash states.

Dependencies

~245KB