[tor-commits] [meek/master] A few doc comments.

dcf at torproject.org dcf at torproject.org
Tue Apr 29 13:37:28 UTC 2014


commit 90f4223a329f6791b0cbfc8f65e2dd37f31b976a
Author: David Fifield <david at bamsoftware.com>
Date:   Sat Apr 26 21:15:22 2014 -0700

    A few doc comments.
---
 appengine/reflect.go       |    9 +++++++++
 firefox/components/main.js |    3 +++
 latencytest/README         |    3 +++
 latencytest/latencytest.go |    3 +++
 meek-client/meek-client.go |    1 +
 5 files changed, 19 insertions(+)

diff --git a/appengine/reflect.go b/appengine/reflect.go
index 863a738..27c5941 100644
--- a/appengine/reflect.go
+++ b/appengine/reflect.go
@@ -1,3 +1,5 @@
+// A web app for Google App Engine that proxies HTTP requests and responses to a
+// Tor relay running meek-server.
 package reflect
 
 import (
@@ -18,6 +20,7 @@ const (
 
 var context appengine.Context
 
+// Join two URL paths.
 func pathJoin(a, b string) string {
 	if len(a) > 0 && a[len(a)-1] == '/' {
 		a = a[:len(a)-1]
@@ -37,11 +40,15 @@ var reflectedHeaderFields = []string{
 	"X-Session-Id",
 }
 
+// Make a copy of r, with the URL being changed to be relative to forwardURL,
+// and including only the headers in reflectedHeaderFields.
 func copyRequest(r *http.Request) (*http.Request, error) {
 	u, err := url.Parse(forwardURL)
 	if err != nil {
 		return nil, err
 	}
+	// Append the requested path to the path in forwardURL, so that
+	// forwardURL can be something like "http://example.com/reflect".
 	u.Path = pathJoin(u.Path, r.URL.Path)
 	c, err := http.NewRequest(r.Method, u.String(), r.Body)
 	if err != nil {
@@ -64,6 +71,8 @@ func handler(w http.ResponseWriter, r *http.Request) {
 		http.Error(w, err.Error(), http.StatusInternalServerError)
 		return
 	}
+	// Use urlfetch.Transport directly instead of urlfetch.Client because we
+	// want only a single HTTP transaction, not following redirects.
 	transport := urlfetch.Transport{
 		Context: context,
 		// Despite the name, Transport.Deadline is really a timeout and
diff --git a/firefox/components/main.js b/firefox/components/main.js
index b07ed84..bef833f 100644
--- a/firefox/components/main.js
+++ b/firefox/components/main.js
@@ -229,12 +229,15 @@ MeekHTTPHelper.RequestReader = function(transport, callback) {
         Components.interfaces.nsITransport.OPEN_BLOCKING | Components.interfaces.nsITransport.OPEN_UNBUFFERED, 0, 0);
 
     this.state = this.STATE_READING_LENGTH;
+    // Initially size the buffer to read the 4-byte length.
     this.buf = new Uint8Array(4);
     this.bytesToRead = this.buf.length;
     this.deadline = Date.now() + MeekHTTPHelper.LOCAL_READ_TIMEOUT * 1000;
     this.asyncWait();
 };
 MeekHTTPHelper.RequestReader.prototype = {
+    // The onInputStreamReady callback is called for all read events. These
+    // constants keep track of the state of parsing.
     STATE_READING_LENGTH: 1,
     STATE_READING_OBJECT: 2,
     STATE_DONE: 3,
diff --git a/latencytest/README b/latencytest/README
new file mode 100644
index 0000000..c96e60c
--- /dev/null
+++ b/latencytest/README
@@ -0,0 +1,3 @@
+This is an App Engine web app that measures the latency between the App
+Engine servers and other endpoints. A copy of this app is running at
+http://meek-latency-test.appspot.com/.
diff --git a/latencytest/latencytest.go b/latencytest/latencytest.go
index 0244bd6..4c248a2 100644
--- a/latencytest/latencytest.go
+++ b/latencytest/latencytest.go
@@ -1,3 +1,6 @@
+// This program tests the HTTP round-trip time from App Engine to various
+// endpoints. It does several POSTS to each endpoint and then draws a graph
+// showing the round-trip time.
 package latencytest
 
 import (
diff --git a/meek-client/meek-client.go b/meek-client/meek-client.go
index d6b095f..f293b67 100644
--- a/meek-client/meek-client.go
+++ b/meek-client/meek-client.go
@@ -151,6 +151,7 @@ func handler(conn *pt.SocksConn) error {
 	}()
 
 	defer conn.Close()
+	// Ignore the IP address in the SOCKS request.
 	err := conn.Grant(&net.TCPAddr{IP: net.ParseIP("0.0.0.0"), Port: 0})
 	if err != nil {
 		return err



More information about the tor-commits mailing list