Commit Graph

10 Commits

Author SHA1 Message Date
Yawning Angel
b579f6f4d4 Use io.ReadFull in places where it is appropriate. 2014-05-26 04:43:46 +00:00
Yawning Angel
8cd2e1f0f9 Randomize length when the decoder receives an out-of-bound value.
This makes the length error and MAC error indistinguishable to an
external attacker.
2014-05-24 05:06:34 +00:00
Yawning Angel
19f34317ba Change the MSS to 1448 bytes, because timestamps are a thing.
This breaks wireprotocol compatibility.
2014-05-21 01:45:17 +00:00
Yawning Angel
1fee9678c6 Change the length field obfscation.
Instead of including the previous secretbox in the input when
calculating the  SipHash-2-4 digest used to generate the obfuscation
mask, use only the nonce.  This is significantly faster, and if someone
breaks obfs4 by exploiting the low amount of input entropy between each
invocation (a counter incrementing by 1), I hope they publish the
attack on the PRF.

This breaks wire protocol compatibility.
2014-05-16 02:54:17 +00:00
Yawning Angel
48c6f06d04 Change the framing Encoder/Decoder to take the destination slice.
In theory this is easier on the garbage collector.  Probably could
reuse more of the intermediary buffers by stashing them in the
connection state, but that makes the code kind of messy.  This should
be an improvement.
2014-05-14 09:58:53 +00:00
Yawning Angel
89d5338eed Fix comment (No functional changes). 2014-05-14 08:13:42 +00:00
Yawning Angel
51a8dd5a86 Fix logging again.
On second thought instead of using log.Panicf(), panic() and do the
logging with recover().  This somewhat centralizes logging in
obfs4proxy, which will be easier to change when I invariably decide to
do logging differently in the future.
2014-05-12 23:04:39 +00:00
Yawning Angel
9712aec73b Preliminary support padding, log on panic.
This adds preliminary support for data padding by adding another layer
of encapsulation inside each AEAD frame containing a type and length.
For now, data is still sent unpadded, but the infrastructure for
supporting it is mostly there.

Additionally, use log.Panic[f]() instead of panic through out the code
so that some panics are logged.
2014-05-12 04:51:06 +00:00
Yawning Angel
f76f142340 Change documentation/comments to reflect reality (No functional changes). 2014-05-11 21:55:34 +00:00
Yawning Angel
ef38b844f9 Initial import. 2014-05-09 10:23:58 +00:00