-
Notifications
You must be signed in to change notification settings - Fork 88
Confirmation Code
Transmitter, Relay, and Receiver Programs of the user talk to each other over serial interfaces. In an asynchronous serial interface, unrecoverable transmission errors are inevitable. The rate at which they occur depend on multiple things:
- quality of the serial adapters
- data diode components and build quality
- baud rate (speed setting of the serial interface)
- the amount error correction
- interference from external noise
Because TFC's security relies on unidirectional communication between the programs, there is no automated way to ask packets to be re-transferred. To prevent a situation where important data such as Onion Service private key, PSK or X448-derived keys do not reach their destination, TFC uses something called a confirmation code. Confirmation code is a two hexadecimal (0..9 and a..f) code that is quick to type but annoying enough to guess.
Example of a confirmation code prompt
In the event data does not reach its destination and the user does not see the correct confirmation code on the program specified by the Transmitter Program (from Relay
means confirmation code should be visible on Relay Program on Networked Computer), data can be re-transferred simply by pressing enter
as many times as needed until the packet reached its destination and the receiving program displays the confirmation code.
Confirmation codes are not sensitive in any way.