2019-07-04 00:46:59 +03:00
|
|
|
package app
|
|
|
|
|
|
|
|
import (
|
2019-08-08 13:08:29 +03:00
|
|
|
"errors"
|
2019-07-04 00:46:59 +03:00
|
|
|
"fmt"
|
|
|
|
"os"
|
|
|
|
|
|
|
|
"github.com/wybiral/torgo"
|
|
|
|
"github.com/wybiral/tube/pkg/onionkey"
|
|
|
|
)
|
|
|
|
|
|
|
|
type tor struct {
|
|
|
|
OnionKey onionkey.Key
|
|
|
|
Controller *torgo.Controller
|
|
|
|
}
|
|
|
|
|
|
|
|
func newTor(ct *TorConfig) (*tor, error) {
|
|
|
|
addr := fmt.Sprintf("%s:%d", ct.Controller.Host, ct.Controller.Port)
|
|
|
|
ctrl, err := torgo.NewController(addr)
|
|
|
|
if err != nil {
|
2019-08-08 13:08:29 +03:00
|
|
|
return nil, errors.New("unable to connect to Tor controller")
|
2019-07-04 00:46:59 +03:00
|
|
|
}
|
|
|
|
if len(ct.Controller.Password) > 0 {
|
|
|
|
err = ctrl.AuthenticatePassword(ct.Controller.Password)
|
|
|
|
} else {
|
|
|
|
err = ctrl.AuthenticateCookie()
|
|
|
|
if err != nil {
|
|
|
|
err = ctrl.AuthenticateNone()
|
|
|
|
}
|
|
|
|
}
|
|
|
|
if err != nil {
|
2019-08-08 13:08:29 +03:00
|
|
|
return nil, errors.New("unable to authenticate to Tor controller")
|
2019-07-04 00:46:59 +03:00
|
|
|
}
|
|
|
|
key, err := onionkey.ReadFile("onion.key")
|
|
|
|
if os.IsNotExist(err) {
|
|
|
|
key = nil
|
|
|
|
} else if err != nil {
|
|
|
|
return nil, err
|
|
|
|
}
|
|
|
|
t := &tor{
|
|
|
|
Controller: ctrl,
|
|
|
|
OnionKey: key,
|
|
|
|
}
|
|
|
|
return t, nil
|
|
|
|
}
|