[tor-commits] [obfs-flash/master] Simulate loading configuration from a file.

dcf at torproject.org dcf at torproject.org
Wed Dec 4 10:14:44 UTC 2013


commit 34047d7cae18337ff9eb56809f3cd2447a85c894
Author: David Fifield <david at bamsoftware.com>
Date:   Wed Dec 4 01:56:02 2013 -0800

    Simulate loading configuration from a file.
---
 obfs-flash-server.go |   76 +++++++++++++++++++++++++++++++++++++++++++-------
 1 file changed, 66 insertions(+), 10 deletions(-)

diff --git a/obfs-flash-server.go b/obfs-flash-server.go
index e70b842..20b5b65 100644
--- a/obfs-flash-server.go
+++ b/obfs-flash-server.go
@@ -155,7 +155,7 @@ type ServerTransportPlugin struct {
 	Command    []string
 }
 
-func startProcesses(connectBackAddr net.Addr) (bindAddr *net.TCPAddr, procs ProcList, err error) {
+func startProcesses(connectBackAddr net.Addr, plugins []ServerTransportPlugin) (bindAddr *net.TCPAddr, procs ProcList, err error) {
 	var stdout io.ReadCloser
 
 	defer func() {
@@ -166,11 +166,6 @@ func startProcesses(connectBackAddr net.Addr) (bindAddr *net.TCPAddr, procs Proc
 		}
 	}()
 
-	plugins := []ServerTransportPlugin{
-		{"obfs3", []string{"obfsproxy", "managed"}},
-		{"websocket", []string{"websocket-server"}},
-	}
-
 	bindAddr = connectBackAddr.(*net.TCPAddr)
 	for _, plugin := range plugins {
 		// This plugin has its TOR_PT_ORPORT set to the previous
@@ -327,7 +322,7 @@ loop:
 	}
 }
 
-func startChain(bindAddr *net.TCPAddr) (*Chain, error) {
+func startChain(bindAddr *net.TCPAddr, plugins []ServerTransportPlugin) (*Chain, error) {
 	chain := &Chain{}
 	var err error
 
@@ -343,7 +338,7 @@ func startChain(bindAddr *net.TCPAddr) (*Chain, error) {
 	log("Internal listener on %s.", chain.IntLn.Addr())
 
 	// Start subprocesses.
-	chain.ProcsAddr, chain.Procs, err = startProcesses(chain.IntLn.Addr())
+	chain.ProcsAddr, chain.Procs, err = startProcesses(chain.IntLn.Addr(), plugins)
 	if err != nil {
 		log("Error starting proxy chain: %s.", err)
 		chain.Shutdown()
@@ -366,6 +361,59 @@ func startChain(bindAddr *net.TCPAddr) (*Chain, error) {
 	return chain, nil
 }
 
+type Configuration struct {
+	// Map from method names to command strings.
+	Transports map[string][]string
+	// Map from tor-friendly names like "obfs3_websocket" to systematic
+	// names like "obfs3|websocket".
+	Aliases map[string]string
+}
+
+func (conf *Configuration) MethodNames() []string {
+	result := make([]string, 0)
+	// We understand all the single transports
+	for k, _ := range conf.Transports {
+		result = append(result, k)
+	}
+	// and aliases.
+	for k, _ := range conf.Aliases {
+		result = append(result, k)
+	}
+	return result
+}
+
+// Parse a (possibly composed) method name into a slice of single method names.
+func (conf *Configuration) ParseMethodName(methodName string) []string {
+	if name, ok := conf.Aliases[methodName]; ok {
+		methodName = name
+	}
+	return strings.Split(methodName, "|")
+}
+
+func (conf *Configuration) PluginList(methodName string) ([]ServerTransportPlugin, error) {
+	names := conf.ParseMethodName(methodName)
+	stp := make([]ServerTransportPlugin, 0)
+	for _, name := range names {
+		command, ok := conf.Transports[name]
+		if !ok {
+			return nil, errors.New(fmt.Sprintf("no transport named %q", name))
+		}
+		stp = append(stp, ServerTransportPlugin{name, command})
+	}
+	return stp, nil
+}
+
+// Simulate loading a configuration file.
+func getConfiguration() (conf *Configuration) {
+	conf = new(Configuration)
+	conf.Transports = make(map[string][]string)
+	conf.Aliases = make(map[string]string)
+	conf.Transports["obfs3"] = []string{"obfsproxy", "managed"}
+	conf.Transports["websocket"] = []string{"websocket-server"}
+	conf.Aliases["obfs3_websocket"] = "obfs3|websocket"
+	return conf
+}
+
 func main() {
 	var logFilename string
 	var port int
@@ -385,7 +433,9 @@ func main() {
 	}
 
 	log("Starting.")
-	ptInfo = pt.ServerSetup([]string{ptMethodName})
+
+	conf := getConfiguration()
+	ptInfo = pt.ServerSetup(conf.MethodNames())
 
 	chains := make([]*Chain, 0)
 	for _, bindAddr := range ptInfo.BindAddrs {
@@ -396,7 +446,13 @@ func main() {
 			bindAddr.Addr.Port = port
 		}
 
-		chain, err := startChain(bindAddr.Addr)
+		plugins, err := conf.PluginList(bindAddr.MethodName)
+		if err != nil {
+			pt.SmethodError(bindAddr.MethodName, err.Error())
+			continue
+		}
+
+		chain, err := startChain(bindAddr.Addr, plugins)
 		if err != nil {
 			pt.SmethodError(bindAddr.MethodName, err.Error())
 			continue



More information about the tor-commits mailing list