summaryrefslogtreecommitdiff
path: root/transports
diff options
context:
space:
mode:
Diffstat (limited to 'transports')
-rw-r--r--transports/transports.go19
1 files changed, 11 insertions, 8 deletions
diff --git a/transports/transports.go b/transports/transports.go
index 5cfd468..021b176 100644
--- a/transports/transports.go
+++ b/transports/transports.go
@@ -42,6 +42,7 @@ import (
"github.com/OperatorFoundation/shapeshifter-transports/transports/obfs4"
"github.com/OperatorFoundation/shapeshifter-transports/transports/shadow"
"github.com/mufti1/interconv/package"
+ "golang.org/x/net/proxy"
gourl "net/url"
"strconv"
)
@@ -51,7 +52,7 @@ func Transports() []string {
return []string{"obfs2", "shadow", "obfs4", "Optimizer"}
}
-func ParseArgsObfs4(args map[string]interface{}, target string) (*obfs4.Transport, error) {
+func ParseArgsObfs4(args map[string]interface{}, target string, dialer proxy.Dialer) (*obfs4.Transport, error) {
var cert string
var iatMode int
@@ -140,6 +141,7 @@ func ParseArgsObfs4(args map[string]interface{}, target string) (*obfs4.Transpor
CertString: cert,
IatMode: iatMode,
Address: target,
+ Dialer: dialer,
}
return &transport, nil
@@ -687,7 +689,7 @@ func ParseArgsMeeklite(args map[string]interface{}, target string) (*meeklite.Tr
return &transport, nil
}
-func ParseArgsOptimizer(args map[string]interface{}) (*Optimizer.Client, error) {
+func ParseArgsOptimizer(args map[string]interface{}, dialer proxy.Dialer) (*Optimizer.Client, error) {
var transports []Optimizer.Transport
var strategy Optimizer.Strategy
@@ -701,7 +703,7 @@ func ParseArgsOptimizer(args map[string]interface{}) (*Optimizer.Client, error)
otcs := untypedTransports.([]interface{})
var parseErr error
- transports, parseErr = parseTransports(otcs)
+ transports, parseErr = parseTransports(otcs, dialer)
if parseErr != nil {
return nil, errors.New("could not parse transports")
}
@@ -758,13 +760,13 @@ func parseStrategy(strategyString string, transports []Optimizer.Transport) (Opt
}
}
-func parseTransports(otcs []interface{}) ([]Optimizer.Transport, error) {
+func parseTransports(otcs []interface{}, dialer proxy.Dialer) ([]Optimizer.Transport, error) {
transports := make([]Optimizer.Transport, len(otcs))
for index, untypedOtc := range otcs {
switch untypedOtc.(type) {
case map[string]interface{}:
otc := untypedOtc.(map[string]interface{})
- transport, err := parsedTransport(otc)
+ transport, err := parsedTransport(otc, dialer)
if err != nil {
return nil, errors.New("transport could not parse config")
//this error sucks and is uninformative
@@ -778,10 +780,11 @@ func parseTransports(otcs []interface{}) ([]Optimizer.Transport, error) {
return transports, nil
}
-func parsedTransport(otc map[string]interface{}) (Optimizer.Transport, error) {
+func parsedTransport(otc map[string]interface{}, dialer proxy.Dialer) (Optimizer.Transport, error) {
var address string
var name string
var config map[string]interface{}
+
//start by parsing the address
untypedAddress, ok := otc["address"]
if !ok {
@@ -841,7 +844,7 @@ func parsedTransport(otc map[string]interface{}) (Optimizer.Transport, error) {
}
return shadowTransport, nil
case "obfs4":
- obfs4Transport, parseErr := ParseArgsObfs4(config, address)
+ obfs4Transport, parseErr := ParseArgsObfs4(config, address, dialer)
if parseErr != nil {
return nil, errors.New("could not parse obfs4 Args")
}
@@ -865,7 +868,7 @@ func parsedTransport(otc map[string]interface{}) (Optimizer.Transport, error) {
}
return replicantTransport, nil
case "Optimizer":
- optimizerTransport, parseErr := ParseArgsOptimizer(config)
+ optimizerTransport, parseErr := ParseArgsOptimizer(config, dialer)
if parseErr != nil {
return nil, errors.New("could not parse Optimizer Args")
}