From 45e2e7b4f924db0a62c5d1dd65a59c29c1bdba4b Mon Sep 17 00:00:00 2001 From: Misha Padalka Date: Tue, 8 Apr 2014 02:05:11 +0300 Subject: [PATCH 1/6] Add Ubuntu's AppIndicator support --- configure.ac | 11 ++++++++ src/Makefile.am | 4 ++- src/gopenvpn.c | 68 +++++++++++++++++++++++++++++++++++++++++++++++++ src/gopenvpn.h | 9 +++++++ 4 files changed, 91 insertions(+), 1 deletion(-) diff --git a/configure.ac b/configure.ac index 64e4fd5..86d9c07 100644 --- a/configure.ac +++ b/configure.ac @@ -65,6 +65,17 @@ AC_SUBST(X11_LIBS) PKG_CHECK_MODULES(POLKIT, polkit-gobject-1 >= 0.96) +# Check for AppIndicator +APPINDICATOR_LIBS= + +PKG_CHECK_MODULES(APPINDICATOR, appindicator-0.1, + [AC_DEFINE([USE_APPINDICATOR],[1],[Use AppIndicator1-0.1])], + [AC_MSG_WARN(AppIndicator 1-0.1 not present")]) + +AM_CONDITIONAL(APPINDICATOR, test -n "$APPINDICATOR_LIBS") +AC_SUBST(APPINDICATOR_CFLAGS) +AC_SUBST(APPINDICATOR_LIBS) + # Check for PolicyKit pkexec - can be overridden by --with-pkexec AC_ARG_WITH([pkexec], AC_HELP_STRING([--with-pkexec=/path/to/pkexec], [Full path to PolicyKit pkexec])) diff --git a/src/Makefile.am b/src/Makefile.am index 598a564..c62cc1f 100644 --- a/src/Makefile.am +++ b/src/Makefile.am @@ -9,13 +9,15 @@ endif gopenvpn_LDADD = $(GTK_LIBS) \ $(GLADE_LIBS) \ $(GNOME_KEYRING_LIBS) \ - $(X11_LIBS) + $(X11_LIBS) \ + $(APPINDICATOR_LIBS) AM_CFLAGS = -Wall -ansi -pedantic \ $(GLADE_CFLAGS) \ $(GNOME_KEYRING_CFLAGS) \ $(GTK_CFLAGS) \ $(X11_CFLAGS) \ + $(APPINDICATOR_CFLAGS) \ -DPIXMAPS_DIR=\""$(datadir)/gopenvpn"\" \ -DSYSCONF_DIR=\""$(sysconfdir)"\" \ -DLOCALSTATE_DIR=\""$(localstatedir)"\" \ diff --git a/src/gopenvpn.c b/src/gopenvpn.c index c01e746..a6597ac 100644 --- a/src/gopenvpn.c +++ b/src/gopenvpn.c @@ -82,6 +82,10 @@ #include "eggtrayicon.h" #endif +#ifdef USE_APPINDICATOR +#include +#endif + /* * VPNConfig Section */ @@ -149,6 +153,11 @@ struct VPNApplet GHashTable *configs_table; gboolean batchmode; +#ifdef USE_APPINDICATOR + AppIndicator *app_indicator; + gboolean icon_blinking; + gboolean blink_on; +#endif #ifdef USE_GTKSTATUSICON GtkStatusIcon *status_icon; #else @@ -1008,6 +1017,9 @@ VPNApplet *vpn_applet_new() self->preferences = NULL; self->configs_table = NULL; self->batchmode = FALSE; + #ifdef USE_APPINDICATOR + self->app_indicator = NULL; + #endif #ifdef USE_GTKSTATUSICON self->status_icon = NULL; #else @@ -1142,6 +1154,22 @@ gboolean vpn_applet_blink_icon(gpointer user_data) } #endif +#ifdef USE_APPINDICATOR +gboolean app_indicator_blink_icon(gpointer user_data) +{ + VPNApplet *applet = (VPNApplet*)user_data; + + if (!applet->icon_blinking) + return FALSE; + + app_indicator_set_icon(applet->app_indicator, applet->blink_on ? CONNECTING_IMAGE_AI : BLINK_IMAGE_AI); + + applet->blink_on = !applet->blink_on; + + return TRUE; +} +#endif + gboolean vpn_applet_get_password(VPNApplet *applet, const char *name, char **username, @@ -1225,6 +1253,30 @@ gboolean vpn_applet_get_password(VPNApplet *applet, void vpn_applet_set_icon_state(VPNApplet *applet, int state) { + #ifdef USE_APPINDICATOR + switch (state) + { + case INACTIVE: + applet->icon_blinking = FALSE; + app_indicator_set_icon(applet->app_indicator, CLOSED_IMAGE_AI); + break; + case CONNECTING: + case RECONNECTING: + case SENTSTATE: + if (!applet->icon_blinking) + { + app_indicator_set_icon(applet->app_indicator, CONNECTING_IMAGE_AI); + applet->icon_blinking = TRUE; + applet->blink_on = FALSE; + g_timeout_add(500, app_indicator_blink_icon, applet); + } + break; + case CONNECTED: + applet->icon_blinking = FALSE; + app_indicator_set_icon(applet->app_indicator, OPEN_IMAGE_AI); + break; + } + #endif #ifdef USE_GTKSTATUSICON switch (state) { @@ -1575,6 +1627,11 @@ void vpn_applet_init_popup_menu(VPNApplet *applet) details_item); gtk_menu_shell_append(GTK_MENU_SHELL(applet->menu), quit_item); + + #ifdef USE_APPINDICATOR + app_indicator_set_menu(applet->app_indicator, GTK_MENU(applet->menu)); + gtk_widget_show_all(applet->menu); + #endif } void vpn_applet_init_configs(VPNApplet *applet) @@ -1664,6 +1721,12 @@ void vpn_applet_reconnect_to_mgmt(VPNApplet *applet) void vpn_applet_init_status_icon(VPNApplet *applet) { + #ifdef USE_APPINDICATOR + applet->app_indicator = app_indicator_new_with_path("gopenvpn-icon", "gopenvpn", APP_INDICATOR_CATEGORY_OTHER, PIXMAPS_DIR); + app_indicator_set_status(applet->app_indicator, APP_INDICATOR_STATUS_ACTIVE); + app_indicator_set_icon(applet->app_indicator, CLOSED_IMAGE_AI); + app_indicator_set_title(applet->app_indicator, "GOpenVPN"); + #endif #ifdef USE_GTKSTATUSICON applet->status_icon = gtk_status_icon_new_from_file(applet->closed_image); @@ -1711,6 +1774,11 @@ void vpn_applet_destroy(VPNApplet *applet) if (applet->batchmode) return; + #ifdef USE_APPINDICATOR + if (applet->app_indicator) { + app_indicator_set_status(applet->app_indicator, APP_INDICATOR_STATUS_PASSIVE); + } + #endif #ifdef USE_GTKSTATUSICON if (applet->status_icon) g_object_unref(applet->status_icon); diff --git a/src/gopenvpn.h b/src/gopenvpn.h index 68931ef..c4457d8 100644 --- a/src/gopenvpn.h +++ b/src/gopenvpn.h @@ -25,6 +25,15 @@ #define OPEN_IMAGE "gopenvpn-open.png" +/* For AppIndicator */ +#define CLOSED_IMAGE_AI "gopenvpn-closed" + +#define CONNECTING_IMAGE_AI "gopenvpn-connecting" + +#define BLINK_IMAGE_AI "gopenvpn-blink" + +#define OPEN_IMAGE_AI "gopenvpn-open" + #define GLADE_FILE "gopenvpn.glade" #define CONFIG_PATH "/etc/openvpn" From 5bfe063a2778f375dfd6eddaf62e93a17b6a457c Mon Sep 17 00:00:00 2001 From: Misha Padalka Date: Tue, 8 Apr 2014 02:16:57 +0300 Subject: [PATCH 2/6] Fix icon blinking on first connect --- src/gopenvpn.c | 4 +++- 1 file changed, 3 insertions(+), 1 deletion(-) diff --git a/src/gopenvpn.c b/src/gopenvpn.c index a6597ac..62df56c 100644 --- a/src/gopenvpn.c +++ b/src/gopenvpn.c @@ -1019,6 +1019,8 @@ VPNApplet *vpn_applet_new() self->batchmode = FALSE; #ifdef USE_APPINDICATOR self->app_indicator = NULL; + self->icon_blinking = FALSE; + self->blink_on = FALSE; #endif #ifdef USE_GTKSTATUSICON self->status_icon = NULL; @@ -1263,9 +1265,9 @@ void vpn_applet_set_icon_state(VPNApplet *applet, int state) case CONNECTING: case RECONNECTING: case SENTSTATE: + app_indicator_set_icon(applet->app_indicator, CONNECTING_IMAGE_AI); if (!applet->icon_blinking) { - app_indicator_set_icon(applet->app_indicator, CONNECTING_IMAGE_AI); applet->icon_blinking = TRUE; applet->blink_on = FALSE; g_timeout_add(500, app_indicator_blink_icon, applet); From 20ee3a079bd97665ed883cf5432ef6b9b3b66442 Mon Sep 17 00:00:00 2001 From: Misha Padalka Date: Sun, 1 Jun 2014 15:06:22 +0300 Subject: [PATCH 3/6] Change icons for Ubuntu's AppIndicator --- pixmaps/Makefile.am | 6 ++- pixmaps/gopenvpn-active.svg | 64 +++++++++++++++++++++++++++++++ pixmaps/gopenvpn-inactive.svg | 64 +++++++++++++++++++++++++++++++ pixmaps/gopenvpn-processing-2.svg | 64 +++++++++++++++++++++++++++++++ pixmaps/gopenvpn-processing.svg | 64 +++++++++++++++++++++++++++++++ src/gopenvpn.h | 8 ++-- 6 files changed, 265 insertions(+), 5 deletions(-) create mode 100644 pixmaps/gopenvpn-active.svg create mode 100644 pixmaps/gopenvpn-inactive.svg create mode 100644 pixmaps/gopenvpn-processing-2.svg create mode 100644 pixmaps/gopenvpn-processing.svg diff --git a/pixmaps/Makefile.am b/pixmaps/Makefile.am index 58de846..135882a 100644 --- a/pixmaps/Makefile.am +++ b/pixmaps/Makefile.am @@ -2,5 +2,9 @@ pixmapsdir = $(datadir)/gopenvpn pixmaps_DATA = gopenvpn-open.png \ gopenvpn-connecting.png \ gopenvpn-blink.png \ - gopenvpn-closed.png + gopenvpn-closed.png \ + gopenvpn-active.svg \ + gopenvpn-inactive.svg \ + gopenvpn-processing.svg \ + gopenvpn-processing-2.svg EXTRA_DIST = $(pixmaps_DATA) diff --git a/pixmaps/gopenvpn-active.svg b/pixmaps/gopenvpn-active.svg new file mode 100644 index 0000000..21a9264 --- /dev/null +++ b/pixmaps/gopenvpn-active.svg @@ -0,0 +1,64 @@ + + + + + + + + + + image/svg+xml + + + + + + + + diff --git a/pixmaps/gopenvpn-inactive.svg b/pixmaps/gopenvpn-inactive.svg new file mode 100644 index 0000000..013bcfe --- /dev/null +++ b/pixmaps/gopenvpn-inactive.svg @@ -0,0 +1,64 @@ + + + + + + + + + + image/svg+xml + + + + + + + + diff --git a/pixmaps/gopenvpn-processing-2.svg b/pixmaps/gopenvpn-processing-2.svg new file mode 100644 index 0000000..6c5c9e4 --- /dev/null +++ b/pixmaps/gopenvpn-processing-2.svg @@ -0,0 +1,64 @@ + + + + + + + + + + image/svg+xml + + + + + + + + diff --git a/pixmaps/gopenvpn-processing.svg b/pixmaps/gopenvpn-processing.svg new file mode 100644 index 0000000..b5896cb --- /dev/null +++ b/pixmaps/gopenvpn-processing.svg @@ -0,0 +1,64 @@ + + + + + + + + + + image/svg+xml + + + + + + + + diff --git a/src/gopenvpn.h b/src/gopenvpn.h index c4457d8..af4334c 100644 --- a/src/gopenvpn.h +++ b/src/gopenvpn.h @@ -26,13 +26,13 @@ #define OPEN_IMAGE "gopenvpn-open.png" /* For AppIndicator */ -#define CLOSED_IMAGE_AI "gopenvpn-closed" +#define CLOSED_IMAGE_AI "gopenvpn-inactive" -#define CONNECTING_IMAGE_AI "gopenvpn-connecting" +#define CONNECTING_IMAGE_AI "gopenvpn-processing" -#define BLINK_IMAGE_AI "gopenvpn-blink" +#define BLINK_IMAGE_AI "gopenvpn-processing-2" -#define OPEN_IMAGE_AI "gopenvpn-open" +#define OPEN_IMAGE_AI "gopenvpn-active" #define GLADE_FILE "gopenvpn.glade" From 6672a152ec02ef2a4ac1e5aaf6f9db4ac0046a5d Mon Sep 17 00:00:00 2001 From: Misha Padalka Date: Mon, 23 Jun 2014 09:26:46 +0300 Subject: [PATCH 4/6] Small icon change --- pixmaps/gopenvpn-processing-2.svg | 8 ++++---- 1 file changed, 4 insertions(+), 4 deletions(-) diff --git a/pixmaps/gopenvpn-processing-2.svg b/pixmaps/gopenvpn-processing-2.svg index 6c5c9e4..8b7344a 100644 --- a/pixmaps/gopenvpn-processing-2.svg +++ b/pixmaps/gopenvpn-processing-2.svg @@ -14,7 +14,7 @@ width="16" version="1.0" inkscape:version="0.48.4 r9939" - sodipodi:docname="gopenvpn-processing.svg"> + sodipodi:docname="gopenvpn-processing-2.svg"> image/svg+xml - + @@ -56,9 +56,9 @@ class="fil1" id="_2_O" /> From 6f8d51a19ca0b42a3758b09f3776a8fe3dd391eb Mon Sep 17 00:00:00 2001 From: Misha Padalka Date: Fri, 28 Dec 2018 14:11:03 +0200 Subject: [PATCH 5/6] Fix build with newer autotools --- configure.ac | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/configure.ac b/configure.ac index 86d9c07..a2dae41 100644 --- a/configure.ac +++ b/configure.ac @@ -21,7 +21,7 @@ AC_PREREQ([2.59]) AC_INIT([gopenvpn], [0.8], [gopenvpn-users@lists.sourceforge.net]) AC_CONFIG_AUX_DIR([.]) AM_INIT_AUTOMAKE([foreign -Wall -Werror]) -AM_GNU_GETTEXT_VERSION([0.18.1]) +AM_GNU_GETTEXT_VERSION([0.18.3]) AM_GNU_GETTEXT([external]) AC_PROG_CC From a85cf3291e0124adb3336708f5cf87ff7e9ff672 Mon Sep 17 00:00:00 2001 From: Misha Padalka Date: Sat, 17 Aug 2019 22:42:31 +0300 Subject: [PATCH 6/6] Use libsecret instead of deprecated libgnome-keyring when available --- configure.ac | 15 +++++-- debian/control | 4 +- debian/gopenvpn.substvars | 3 +- src/Makefile.am | 2 + src/gopenvpn.c | 82 +++++++++++++++++++++++++++++++++++++++ src/gopenvpn.h | 6 +++ 6 files changed, 106 insertions(+), 6 deletions(-) diff --git a/configure.ac b/configure.ac index a2dae41..00c1cd1 100644 --- a/configure.ac +++ b/configure.ac @@ -47,6 +47,17 @@ AC_CHECK_FUNCS([socket strrchr]) # Checks for needed packages (pkg-config) PKG_PROG_PKG_CONFIG +PKG_CHECK_MODULES(LIBSECRET, [libsecret-1 >= 0.15], + [AC_DEFINE([HAVE_LIBSECRET], [1], [Use libsecret])], + [PKG_CHECK_MODULES([GNOME_KEYRING], [gnome-keyring-1], + [AC_DEFINE([HAVE_GNOME_KEYRING], [1], [Use gnome-keyring]) + ]) +]) +AC_SUBST(LIBSECRET_CFLAGS) +AC_SUBST(LIBSECRET_LIBS) +AC_SUBST(GNOME_KEYRING_CFLAGS) +AC_SUBST(GNOME_KEYRING_LIBS) + PKG_CHECK_MODULES(GTK, gtk+-2.0) AC_SUBST(GTK_CFLAGS) AC_SUBST(GTK_LIBS) @@ -55,10 +66,6 @@ PKG_CHECK_MODULES(GLADE, libglade-2.0) AC_SUBST(GLADE_CFLAGS) AC_SUBST(GLADE_LIBS) -PKG_CHECK_MODULES(GNOME_KEYRING, gnome-keyring-1) -AC_SUBST(GNOME_KEYRING_CFLAGS) -AC_SUBST(GNOME_KEYRING_LIBS) - PKG_CHECK_MODULES(X11, x11) AC_SUBST(X11_CFLAGS) AC_SUBST(X11_LIBS) diff --git a/debian/control b/debian/control index 8cb749f..62b49d2 100644 --- a/debian/control +++ b/debian/control @@ -2,7 +2,9 @@ Source: gopenvpn Section: net Priority: extra Maintainer: Sam Burney -Build-Depends: debhelper (>= 7), libglib2.0-dev, libgtk2.0-dev, libglade2-dev, libgnome-keyring-dev, build-essential, autogen, automake, autoconf, intltool, libpolkit-gobject-1-dev +Build-Depends: debhelper (>= 7), libglib2.0-dev, libgtk2.0-dev, libglade2-dev, + libsecret-1-dev | libgnome-keyring-dev, + build-essential, autogen, automake, autoconf, intltool, libpolkit-gobject-1-dev Standards-Version: 3.8.0 Homepage: http://gopenvpn.sourceforge.net/ diff --git a/debian/gopenvpn.substvars b/debian/gopenvpn.substvars index ac13204..0082b97 100644 --- a/debian/gopenvpn.substvars +++ b/debian/gopenvpn.substvars @@ -1,2 +1,3 @@ -shlibs:Depends=libatk1.0-0 (>= 1.29.3), libc6 (>= 2.3.6-6~), libc6 (>= 2.4), libcairo2 (>= 1.2.4), libfontconfig1 (>= 2.8.0), libfreetype6 (>= 2.2.1), libglade2-0 (>= 1:2.6.1), libglib2.0-0 (>= 2.23.5), libgnome-keyring0 (>= 2.20.3), libgtk2.0-0 (>= 2.10.0), libpango1.0-0 (>= 1.14.0), libx11-6 (>= 0), libxml2 (>= 2.6.27) +shlibs:Depends=libatk1.0-0 (>= 1.12.4), libc6 (>= 2.3.6-6~), libc6 (>= 2.27), libcairo2 (>= 1.2.4), libfontconfig1 (>= 2.12.6), libfreetype6 (>= 2.2.1), libgdk-pixbuf2.0-0 (>= 2.22.0), libglade2-0 (>= 1:2.6.4-2~), libglib2.0-0 (>= 2.24.0), libgtk2.0-0 (>= 2.10.0), libpango-1.0-0 (>= 1.14.0), libpangocairo-1.0-0 (>= 1.14.0), libpangoft2-1.0-0 (>= 1.14.0), libsecret-1-0 (>= 0.7), libx11-6, libxml2 (>= 2.6.27) misc:Depends= +misc:Pre-Depends= diff --git a/src/Makefile.am b/src/Makefile.am index c62cc1f..2c2f026 100644 --- a/src/Makefile.am +++ b/src/Makefile.am @@ -8,12 +8,14 @@ endif gopenvpn_LDADD = $(GTK_LIBS) \ $(GLADE_LIBS) \ + $(LIBSECRET_LIBS) \ $(GNOME_KEYRING_LIBS) \ $(X11_LIBS) \ $(APPINDICATOR_LIBS) AM_CFLAGS = -Wall -ansi -pedantic \ $(GLADE_CFLAGS) \ + $(LIBSECRET_CFLAGS) \ $(GNOME_KEYRING_CFLAGS) \ $(GTK_CFLAGS) \ $(X11_CFLAGS) \ diff --git a/src/gopenvpn.c b/src/gopenvpn.c index 62df56c..8ed9eaf 100644 --- a/src/gopenvpn.c +++ b/src/gopenvpn.c @@ -47,7 +47,12 @@ #include #include #include +#ifdef HAVE_LIBSECRET +#include +#endif +#ifdef HAVE_GNOME_KEYRING #include +#endif #include "gettext.h" #include "gopenvpn.h" @@ -204,6 +209,82 @@ VPNApplet *g_applet = NULL; * GNOME keyring support */ +#ifdef HAVE_LIBSECRET + +/* schema */ +const SecretSchema * +gopenvpn_get_secret_schema (void) +{ + static const SecretSchema the_schema = { + "org.gnome.gopenvpn.Password", SECRET_SCHEMA_NONE, + { + { "config_name", SECRET_SCHEMA_ATTRIBUTE_STRING }, + { "NULL", 0 }, + } + }; + return &the_schema; +} + +gboolean get_keyring(const char *config_name, + char **username, + char **passphrase) +{ + GError *error = NULL; + char **fields; + + gchar *password = secret_password_lookup_sync (GOPENVPN_SECRET_SCHEMA, + NULL, &error, + "config_name", config_name, + NULL); + if (error != NULL) { + return FALSE; + } else if (password == NULL) { + return FALSE; + } else { + fields = g_strsplit(password, ":", 2); + secret_password_free(password); + + if (g_strv_length(fields) != 2) + { + g_strfreev(fields); + return FALSE; + } + + if (username) + *username = g_strdup(fields[0]); + *passphrase = g_strdup(fields[1]); + g_strfreev(fields); + return TRUE; + } +} + +void set_keyring(const char *config_name, + const char *username, + const char *passphrase) +{ + GError *error = NULL; + + + char *display_name; + char *secret; + + display_name = g_strdup_printf(_("Passphrase for OpenVPN connection %s"), config_name); + secret = g_strdup_printf("%s:%s", username ? username : "", passphrase); + + secret_password_store_sync (GOPENVPN_SECRET_SCHEMA, SECRET_COLLECTION_DEFAULT, + display_name, secret, NULL, &error, + "config_name", config_name, + NULL); + g_assert(error == NULL); + if (error != NULL) { + g_error_free (error); + } + g_free(display_name); + g_free(secret); +} +#endif + +#ifdef HAVE_GNOME_KEYRING gboolean get_keyring(const char *config_name, char **username, char **passphrase) @@ -276,6 +357,7 @@ void set_keyring(const char *config_name, gnome_keyring_attribute_list_free(attributes); g_free(display_name); } +#endif /* * Utility functions diff --git a/src/gopenvpn.h b/src/gopenvpn.h index af4334c..7c52291 100644 --- a/src/gopenvpn.h +++ b/src/gopenvpn.h @@ -39,3 +39,9 @@ #define CONFIG_PATH "/etc/openvpn" #define MAX_RETRY 10 + +#ifdef HAVE_LIBSECRET +const SecretSchema * gopenvpn_get_secret_schema (void) G_GNUC_CONST; + +#define GOPENVPN_SECRET_SCHEMA gopenvpn_get_secret_schema () +#endif