summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
-rw-r--r--autostart.go16
-rw-r--r--bitmaskd.go4
-rw-r--r--main.go7
-rw-r--r--notificator.go46
-rw-r--r--standalone.go12
-rw-r--r--systray.go9
6 files changed, 81 insertions, 13 deletions
diff --git a/autostart.go b/autostart.go
new file mode 100644
index 0000000..62f30cc
--- /dev/null
+++ b/autostart.go
@@ -0,0 +1,16 @@
+package main
+
+type autostart interface {
+ Disable() error
+ Enable() error
+}
+
+type dummyAutostart struct{}
+
+func (a *dummyAutostart) Disable() error {
+ return nil
+}
+
+func (a *dummyAutostart) Enable() error {
+ return nil
+}
diff --git a/bitmaskd.go b/bitmaskd.go
index cb67b8b..d9f8ff0 100644
--- a/bitmaskd.go
+++ b/bitmaskd.go
@@ -24,3 +24,7 @@ import (
func initBitmask() (bitmask.Bitmask, error) {
return bitmaskd.Init()
}
+
+func newAutostart(appName string, iconPath string) autostart {
+ return &dummyAutostart{}
+}
diff --git a/main.go b/main.go
index 75745da..7ce0ba3 100644
--- a/main.go
+++ b/main.go
@@ -81,7 +81,12 @@ func main() {
defer b.Close()
go checkAndStartBitmask(b, notify, conf)
- run(b, conf, notify)
+ as := newAutostart(applicationName, getIconPath())
+ err = as.Enable()
+ if err != nil {
+ log.Printf("Error enabling autostart: %v", err)
+ }
+ run(b, conf, notify, as)
}
func checkAndStartBitmask(b bitmask.Bitmask, notify *notificator, conf *systrayConfig) {
diff --git a/notificator.go b/notificator.go
index 1e9e405..d57e931 100644
--- a/notificator.go
+++ b/notificator.go
@@ -18,6 +18,7 @@ package main
import (
"os"
"path"
+ "runtime"
"time"
"0xacab.org/leap/go-dialog"
@@ -58,7 +59,7 @@ func (n *notificator) donations() {
if n.conf.needsNotification() {
letsDonate := dialog.Message(printer.Sprintf(donationText, applicationName)).
Title(printer.Sprintf("Donate")).
- Icon(getSVGPath()).
+ Icon(getIconPath()).
YesNo()
n.conf.setNotification()
if letsDonate {
@@ -72,32 +73,61 @@ func (n *notificator) donations() {
func (n *notificator) about(version string) {
dialog.Message(printer.Sprintf(aboutText, applicationName, version)).
Title(printer.Sprintf("About")).
- Icon(getSVGPath()).
+ Icon(getIconPath()).
Info()
}
func (n *notificator) bitmaskNotRunning() {
dialog.Message(printer.Sprintf(notRunning)).
Title(printer.Sprintf("Can't contact bitmask")).
- Icon(getSVGPath()).
+ Icon(getIconPath()).
Error()
}
func (n *notificator) authAgent() {
dialog.Message(printer.Sprintf(missingAuthAgent)).
Title(printer.Sprintf("Missing authentication agent")).
- Icon(getSVGPath()).
+ Icon(getIconPath()).
Error()
}
func (n *notificator) errorStartingVPN(err error) {
dialog.Message(printer.Sprintf(errorStartingVPN, applicationName, err)).
Title(printer.Sprintf("Error starting VPN")).
- Icon(getSVGPath()).
+ Icon(getIconPath()).
Error()
}
-func getSVGPath() string {
+func getIconPath() string {
+ gopath := os.Getenv("GOPATH")
+ if gopath == "" {
+ gopath = path.Join(os.Getenv("HOME"), "go")
+ }
+
+ if runtime.GOOS == "windows" {
+ icoPath := `C:\Program Files\RiseupVPN\riseupvpn.ico`
+ if fileExist(icoPath) {
+ return icoPath
+ }
+ icoPath = path.Join(gopath, "src", "0xacab.org", "leap", "riseup_vpn", "assets", "riseupvpn.ico")
+ if fileExist(icoPath) {
+ return icoPath
+ }
+ return ""
+ }
+
+ if runtime.GOOS == "darwin" {
+ icnsPath := "/Applications/RiseupVPN.app/Contents/Resources/app.icns"
+ if fileExist(icnsPath) {
+ return icnsPath
+ }
+ icnsPath = path.Join(gopath, "src", "0xacab.org", "leap", "riseup_vpn", "assets", "riseupvpn.icns")
+ if fileExist(icnsPath) {
+ return icnsPath
+ }
+ return ""
+ }
+
snapPath := os.Getenv("SNAP")
if snapPath != "" {
return snapPath + "/snap/gui/riseupvpn.svg"
@@ -114,10 +144,6 @@ func getSVGPath() string {
return svgPath
}
- gopath := os.Getenv("GOPATH")
- if gopath == "" {
- gopath = path.Join(os.Getenv("HOME"), "go")
- }
svgPath = path.Join(gopath, "src", "0xacab.org", "leap", "bitmask-systray", svgFileName)
if fileExist(svgPath) {
return svgPath
diff --git a/standalone.go b/standalone.go
index cda78f8..a9f135d 100644
--- a/standalone.go
+++ b/standalone.go
@@ -17,10 +17,22 @@
package main
import (
+ "os"
+
"0xacab.org/leap/bitmask-systray/bitmask"
standalone "0xacab.org/leap/bitmask-systray/standalone"
+ pmautostart "github.com/ProtonMail/go-autostart"
)
func initBitmask() (bitmask.Bitmask, error) {
return standalone.Init()
}
+
+func newAutostart(appName string, iconPath string) autostart {
+ return &pmautostart.App{
+ Name: appName,
+ Exec: os.Args,
+ DisplayName: appName,
+ Icon: iconPath,
+ }
+}
diff --git a/systray.go b/systray.go
index 28aeb29..1507ff6 100644
--- a/systray.go
+++ b/systray.go
@@ -39,6 +39,7 @@ type bmTray struct {
mDonate *systray.MenuItem
mCancel *systray.MenuItem
activeGateway *gatewayTray
+ autostart autostart
}
type gatewayTray struct {
@@ -46,8 +47,8 @@ type gatewayTray struct {
name string
}
-func run(bm bitmask.Bitmask, conf *systrayConfig, notify *notificator) {
- bt := bmTray{bm: bm, conf: conf, notify: notify}
+func run(bm bitmask.Bitmask, conf *systrayConfig, notify *notificator, as autostart) {
+ bt := bmTray{bm: bm, conf: conf, notify: notify, autostart: as}
systray.Run(bt.onReady, bt.onExit)
}
@@ -131,6 +132,10 @@ func (bt *bmTray) onReady() {
bt.notify.about(versionStr)
case <-mQuit.ClickedCh:
+ err := bt.autostart.Disable()
+ if err != nil {
+ log.Printf("Error disabling autostart: %v", err)
+ }
systray.Quit()
case <-signalCh:
systray.Quit()