diff options
author | kali kaneko (leap communications) <kali@leap.se> | 2020-06-12 20:35:48 +0200 |
---|---|---|
committer | kali kaneko (leap communications) <kali@leap.se> | 2020-06-12 20:35:48 +0200 |
commit | 4faad2cda4938806126c482c7f93b640d68b9fe8 (patch) | |
tree | e475b65a59ecdfac09bedc7b2ae380736de09c16 /pkg/bitmask | |
parent | 0ac0afaaf312a02af01d1c307ecf9b5915f40b0d (diff) |
[refactor] rename standalone to just vpn
Diffstat (limited to 'pkg/bitmask')
-rw-r--r-- | pkg/bitmask/autostart.go | 45 | ||||
-rw-r--r-- | pkg/bitmask/init.go | 13 | ||||
-rw-r--r-- | pkg/bitmask/standalone.go | 74 |
3 files changed, 57 insertions, 75 deletions
diff --git a/pkg/bitmask/autostart.go b/pkg/bitmask/autostart.go index ebab428..1ba9162 100644 --- a/pkg/bitmask/autostart.go +++ b/pkg/bitmask/autostart.go @@ -1,3 +1,4 @@ +// +build !bitmaskd // Copyright (C) 2018 LEAP // // This program is free software: you can redistribute it and/or modify @@ -15,12 +16,56 @@ package bitmask +import ( + "fmt" + "log" + "os" + "path/filepath" + "regexp" + + pmautostart "github.com/ProtonMail/go-autostart" +) + +const ( + errorMsg = `An error has ocurred initializing the VPN: %v` +) + // Autostart holds the functions to enable and disable the application autostart type Autostart interface { Disable() error Enable() error } +// newAutostart creates a handler for the autostart of your platform +func newAutostart(appName string, iconPath string) Autostart { + exec := os.Args + if os.Getenv("SNAP") != "" { + re := regexp.MustCompile("/snap/([^/]*)/") + match := re.FindStringSubmatch(os.Args[0]) + if len(match) > 1 { + snapName := match[1] + exec = []string{fmt.Sprintf("/snap/bin/%s.launcher", snapName)} + } else { + log.Printf("Snap binary has unknown path: %v", os.Args[0]) + } + } + + if exec[0][:2] == "./" || exec[0][:2] == ".\\" { + var err error + exec[0], err = filepath.Abs(exec[0]) + if err != nil { + log.Printf("Error making the path absolute directory: %v", err) + } + } + + return &pmautostart.App{ + Name: appName, + Exec: exec, + DisplayName: appName, + Icon: iconPath, + } +} + type dummyAutostart struct{} func (a *dummyAutostart) Disable() error { diff --git a/pkg/bitmask/init.go b/pkg/bitmask/init.go index 9af7948..7f10ab9 100644 --- a/pkg/bitmask/init.go +++ b/pkg/bitmask/init.go @@ -16,6 +16,7 @@ package bitmask import ( + "errors" "log" "os" "path" @@ -25,6 +26,7 @@ import ( "0xacab.org/leap/bitmask-vpn/pkg/config" "0xacab.org/leap/bitmask-vpn/pkg/pid" + "0xacab.org/leap/bitmask-vpn/pkg/vpn" ) type ProviderInfo struct { @@ -45,6 +47,15 @@ func InitializeLogger() { } } +func initBitmask(printer *message.Printer) (Bitmask, error) { + b, err := vpn.Init() + if err != nil { + log.Printf("An error ocurred starting bitmask: %v", err) + err = errors.New(printer.Sprintf(errorMsg, err)) + } + return b, err +} + func InitializeBitmask() (Bitmask, error) { if _, err := os.Stat(config.Path); os.IsNotExist(err) { os.MkdirAll(config.Path, os.ModePerm) @@ -60,7 +71,7 @@ func InitializeBitmask() (Bitmask, error) { conf.Version = "unknown" conf.Printer = initPrinter() - b, err := Init(conf.Printer) + b, err := initBitmask(conf.Printer) if err != nil { // TODO notify failure log.Fatal(err) diff --git a/pkg/bitmask/standalone.go b/pkg/bitmask/standalone.go deleted file mode 100644 index 92ea542..0000000 --- a/pkg/bitmask/standalone.go +++ /dev/null @@ -1,74 +0,0 @@ -// +build !bitmaskd -// Copyright (C) 2018 LEAP -// -// This program is free software: you can redistribute it and/or modify -// it under the terms of the GNU General Public License as published by -// the Free Software Foundation, either version 3 of the License, or -// (at your option) any later version. -// -// This program is distributed in the hope that it will be useful, -// but WITHOUT ANY WARRANTY; without even the implied warranty of -// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the -// GNU General Public License for more details. -// -// You should have received a copy of the GNU General Public License -// along with this program. If not, see <http://www.gnu.org/licenses/>. - -package bitmask - -import ( - "errors" - "fmt" - "log" - "os" - "path/filepath" - "regexp" - - "0xacab.org/leap/bitmask-vpn/pkg/standalone" - pmautostart "github.com/ProtonMail/go-autostart" - "golang.org/x/text/message" -) - -const ( - errorMsg = `An error has ocurred initializing the VPN: %v` -) - -// Init bitmask -func Init(printer *message.Printer) (Bitmask, error) { - b, err := standalone.Init() - if err != nil { - log.Printf("An error ocurred starting standalone bitmask: %v", err) - err = errors.New(printer.Sprintf(errorMsg, err)) - } - return b, err -} - -// newAutostart creates a handler for the autostart of your platform -func newAutostart(appName string, iconPath string) Autostart { - exec := os.Args - if os.Getenv("SNAP") != "" { - re := regexp.MustCompile("/snap/([^/]*)/") - match := re.FindStringSubmatch(os.Args[0]) - if len(match) > 1 { - snapName := match[1] - exec = []string{fmt.Sprintf("/snap/bin/%s.launcher", snapName)} - } else { - log.Printf("Snap binary has unknown path: %v", os.Args[0]) - } - } - - if exec[0][:2] == "./" || exec[0][:2] == ".\\" { - var err error - exec[0], err = filepath.Abs(exec[0]) - if err != nil { - log.Printf("Error making the path absolute directory: %v", err) - } - } - - return &pmautostart.App{ - Name: appName, - Exec: exec, - DisplayName: appName, - Icon: iconPath, - } -} |