[tor-commits] [webwml/master] Add 'Make Stegotorus deployment ready' project idea

atagar at torproject.org atagar at torproject.org
Mon Feb 29 16:57:28 UTC 2016


commit fb8533f7efb33698413519fa391f400265ba994d
Author: Damian Johnson <atagar at torproject.org>
Date:   Mon Feb 29 09:00:35 2016 -0800

    Add 'Make Stegotorus deployment ready' project idea
---
 getinvolved/en/volunteer.wml | 138 +++++++++++++++++++++++++++++++++++++++++++
 1 file changed, 138 insertions(+)

diff --git a/getinvolved/en/volunteer.wml b/getinvolved/en/volunteer.wml
index 6c73977..aa53608 100644
--- a/getinvolved/en/volunteer.wml
+++ b/getinvolved/en/volunteer.wml
@@ -1527,6 +1527,144 @@ implementation.
     </p>
     </li>
 
+    <a id="stegotorus"></a>
+    <li>
+    <b>Make Stegotorus deployment ready</b>
+    <br>
+    Language: <i>C++</i>
+    <br>
+    Likely Mentors: <i>vmon</i>
+    <br><br>
+    <p>
+    <a
+    href="https://github.com/TheTorProject/stegotorus/tree/master/src">Stegotorus</a>
+    is a PT framework which streamline the development stealthier pluggable
+    transport. An HTTP pluggable transport is already implemented in Stegotorus
+    framework and can be used when encrypted payloads are throttled and only
+    ephemeral connections are tolerated.
+    </p>
+
+    <p>
+    The majority of work on Stegotorus is done and it can be deployed with a relatively minor improvements including:
+    </p>
+
+    <ul>
+      <li><b>#8098 A config file file for Stegotorus</b>
+        <p>
+        Stegotorus needs many configuration settings specially on the bridge
+        side. This include also the configuration required by each steg module.
+        Currently the configuration is fed to Stegotorus as command line
+        arguments but a file like torrc is needed so all tweaking can be read
+        from there.
+        </p>
+
+        <p><i>
+        Current Status and work needed to be done: The code for reading the
+        config file is written by SRI but it is not yet used in the Stegotorus
+        to read the config.
+        </i></p>
+      </li>
+
+      <li><b>#8101 Debugging the transparent proxy</b>
+        <p>
+        Stegotorus http module uses other websites payload to hide and serve
+        censored traffic. As such it needs to decide if the request is
+        genuinely to the auxiliary website, in that case becomes a transparent
+        proxy and serves the website content as requested, or if the request is
+        actually a request to serve censored material which should be delivered
+        to steg modules.
+        </p>
+
+        <p><i>
+        Current Status: This is completely implemented. However, the transparent proxy sometimes crashes and need to be triaged, debugged and fixed.
+        </i></p>
+      </li>
+
+      <li><b>#11337 refactoring the steg module code</b>
+        <p>
+        The http steg module code, although not essentials to the core of the
+        Stegotorus. needs some improvement and clean up. The solution is to
+        refactor the steg modules as children of FileStegMod.
+        </p>
+
+        <p><i>
+        Current status and work needed to be done: This has already been done
+        but still needs testing and refactoring before it can be reliably merge
+        to the master branch.
+        </i></p>
+      </li>
+
+      <li><b>#8089 Adding Elligator to Stegotorus handshake and test</b>
+        <p>
+        The current Stegotorus handshake is distinguishable from random byte
+        string, which can be used to flag and detect Stegotorus traffic
+        deterministically and need to be implemented similar to
+        ScrambleSuite. Also because the capacity of client to server channel
+        might be slim depending on the choice of steg module it is desirable
+        to be implemented using Elliptic curve crypto. Hence, Elligator
+        protocol is ideal solution for this situation. All we need is to replace Stegotorus handshake by Elligator.
+        </p>
+
+        <p><i>
+        Current Status and work needed to be done: Elligator handshake code is
+        included in stegotorus code base, it is only needed to be called by
+        instead of the current handshake and be tested.
+        </i></p>
+      </li>
+
+      <li><b>Make Stegotorus memory safe by using shared pointers</b>
+        <p>
+        Stegotorus has large code base and it is not written in a memory safe
+        languages. To facilitate its audit, we need to replace (almost all) use
+        of pointers to shared pointers.
+        </p>
+
+        <p><i>
+        Current Status: No progress has not been done.
+        </i></p>
+      </li>
+
+      <li><b>Security Audit and writing more unit test</b>
+        <p>
+        To be able to deploy Stegotorus for real world use we need to audit the
+        code and write more unit test covering new aspects of the Stegotorus
+        (new http transport, proxy server, Elligator handshake)
+        </p>
+
+        <p><i>
+        Current Status: No progress has been done.
+        </i></p>
+      </li>
+
+      <li><b>SRI branch merging</b>
+        <p>
+        Stegotorus has been forked from the initial development from SRI. Now
+        that SRI is hosting Stegotorus publicly it is desirable to merge the
+        two branches so we can benefit from both developments.
+        </p>
+
+        <p><i>
+        Current Status: No progress has been done.
+        </i></p>
+      </li>
+
+      <li><b>#8099 deterministic build</b>
+        <p>
+        To make deterministic build possible we need to build many of
+        Stegotorus dependency from scratch. Boost library is a a huge
+        dependency for Stegotorus to access the file system. As we are only
+        planning to deploy Stegotorus bridges on Linux machines we can simplify
+        such access without that dependency. By dropping such dependency, it
+        should be straight forward to have deterministic build for Stegotorus.
+        </p>
+
+        <p><i>
+        Current Status: No progress has been done.
+        </i></p>
+      </li>
+    </ul>
+    </li>
+
 <!--
     <a id=""></a>
     <li>



More information about the tor-commits mailing list