diff options
author | Ted Gould <ted@gould.cx> | 2014-09-18 16:31:04 -0500 |
---|---|---|
committer | Ted Gould <ted@gould.cx> | 2014-09-18 16:31:04 -0500 |
commit | b255d5ab480f889d96d9b4fc42ba3e0977975660 (patch) | |
tree | b1fd2dee95fa1ff360506deb137c3fd21f0865be /src | |
parent | 86aab4376be3791e1170118805ed44103a5fc2fd (diff) | |
download | ayatana-indicator-messages-b255d5ab480f889d96d9b4fc42ba3e0977975660.tar.gz ayatana-indicator-messages-b255d5ab480f889d96d9b4fc42ba3e0977975660.tar.bz2 ayatana-indicator-messages-b255d5ab480f889d96d9b4fc42ba3e0977975660.zip |
Setup the user manager signals
Diffstat (limited to 'src')
-rw-r--r-- | src/im-accounts-service.c | 30 |
1 files changed, 30 insertions, 0 deletions
diff --git a/src/im-accounts-service.c b/src/im-accounts-service.c index 1926d9b..1dcce7f 100644 --- a/src/im-accounts-service.c +++ b/src/im-accounts-service.c @@ -38,6 +38,8 @@ static void im_accounts_service_class_init (ImAccountsServiceClass *klass); static void im_accounts_service_init (ImAccountsService *self); static void im_accounts_service_dispose (GObject *object); static void im_accounts_service_finalize (GObject *object); +static void user_changed (ActUserManager * manager, ActUser * user, gpointer user_data); +static void is_loaded (ActUserManager * manager, GParamSpec * pspect, gpointer user_data); G_DEFINE_TYPE (ImAccountsService, im_accounts_service, G_TYPE_OBJECT); @@ -58,6 +60,8 @@ im_accounts_service_init (ImAccountsService *self) ImAccountsServicePrivate * priv = IM_ACCOUNTS_SERVICE_GET_PRIVATE(self); priv->user_manager = act_user_manager_get_default(); + g_signal_connect(priv->user_manager, "user-changed", G_CALLBACK(user_changed), self); + g_signal_connect(priv->user_manager, "notify::is-loaded", G_CALLBACK(is_loaded), self); } static void @@ -76,6 +80,32 @@ im_accounts_service_finalize (GObject *object) G_OBJECT_CLASS (im_accounts_service_parent_class)->finalize (object); } +/* Handles a User getting updated */ +static void +user_changed (ActUserManager * manager, ActUser * user, gpointer user_data) +{ + if (g_strcmp0(act_user_get_user_name(user), g_get_user_name()) != 0) { + return; + } + + g_debug("User Updated"); +} + +static void +is_loaded (ActUserManager * manager, GParamSpec * pspect, gpointer user_data) +{ + ImAccountsServicePrivate * priv = IM_ACCOUNTS_SERVICE_GET_PRIVATE(user_data); + ActUser * user = NULL; + + g_debug("Accounts Manager Loaded"); + + user = act_user_manager_get_user(priv->user_manager, g_get_user_name()); + if (user != NULL) { + user_changed(priv->user_manager, user, user_data); + g_object_unref(user); + } +} + /* Not the most testable way to do this but, it is a less invasive one, and we'll probably restructure this codebase soonish */ /* Gets an account service wrapper reference, so then it can be free'd */ |