diff options
Diffstat (limited to 'src')
| -rw-r--r-- | src/Makefile.am | 21 | ||||
| -rw-r--r-- | src/lock-helper.c | 25 | ||||
| -rw-r--r-- | src/org.freedesktop.ConsoleKit.Manager.xml (renamed from src/consolekit-manager.xml) | 0 | ||||
| -rw-r--r-- | src/org.freedesktop.ConsoleKit.Seat.xml | 164 | ||||
| -rw-r--r-- | src/org.freedesktop.ConsoleKit.Session.xml (renamed from src/consolekit-session.xml) | 0 | ||||
| -rw-r--r-- | src/session-service.c | 2 | ||||
| -rw-r--r-- | src/udev-mgr.c | 6 | ||||
| -rw-r--r-- | src/user-menu-mgr.c | 76 | ||||
| -rw-r--r-- | src/user-menu-mgr.h | 3 | ||||
| -rw-r--r-- | src/user-widget.c | 26 | ||||
| -rw-r--r-- | src/users-service-dbus.c | 33 | 
11 files changed, 318 insertions, 38 deletions
| diff --git a/src/Makefile.am b/src/Makefile.am index 36a1d1f..3bfd790 100644 --- a/src/Makefile.am +++ b/src/Makefile.am @@ -25,19 +25,26 @@ libsession_la_CFLAGS = \  libsession_la_LIBADD = $(APPLET_LIBS)  libsession_la_LDFLAGS = -module -avoid-version -consolekit-manager-client.h: $(srcdir)/consolekit-manager.xml +consolekit-manager-client.h: $(srcdir)/org.freedesktop.ConsoleKit.Manager.xml  	dbus-binding-tool \  		--prefix=_consolekit_manager_client \  		--mode=glib-client \  		--output=consolekit-manager-client.h \ -		$(srcdir)/consolekit-manager.xml +		$(srcdir)/org.freedesktop.ConsoleKit.Manager.xml -consolekit-session-client.h: $(srcdir)/consolekit-session.xml +consolekit-seat-client.h: $(srcdir)/org.freedesktop.ConsoleKit.Seat.xml +	dbus-binding-tool \ +		--prefix=_consolekit_seat_client \ +		--mode=glib-client \ +		--output=consolekit-seat-client.h \ +		$(srcdir)/org.freedesktop.ConsoleKit.Seat.xml + +consolekit-session-client.h: $(srcdir)/org.freedesktop.ConsoleKit.Session.xml  	dbus-binding-tool \  		--prefix=_consolekit_session_client \  		--mode=glib-client \  		--output=consolekit-session-client.h \ -		$(srcdir)/consolekit-session.xml +		$(srcdir)/org.freedesktop.ConsoleKit.Session.xml  display-manager-client.h: $(srcdir)/display-manager.xml  	dbus-binding-tool \ @@ -143,6 +150,7 @@ gtk_logout_helper_LDADD = \  BUILT_SOURCES = \  	consolekit-manager-client.h \ +	consolekit-seat-client.h \  	consolekit-session-client.h \  	display-manager-client.h \  	gen-session-dbus.xml.c \ @@ -152,8 +160,9 @@ BUILT_SOURCES = \  	accounts-service-user-client.h  EXTRA_DIST = \ -	consolekit-manager.xml \ -	consolekit-session.xml \ +	org.freedesktop.ConsoleKit.Manager.xml \ +	org.freedesktop.ConsoleKit.Seat.xml \ +	org.freedesktop.ConsoleKit.Session.xml \  	display-manager.xml \  	session-dbus.xml \  	upower.xml \ diff --git a/src/lock-helper.c b/src/lock-helper.c index 9b15070..4c91aa5 100644 --- a/src/lock-helper.c +++ b/src/lock-helper.c @@ -20,12 +20,12 @@ with this program.  If not, see <http://www.gnu.org/licenses/>.  */  #include <glib/gi18n.h> -#include <gconf/gconf-client.h> +#include <gio/gio.h>  #include <dbus/dbus-glib.h>  #include "lock-helper.h" -#define GCONF_DIR  "/apps/gnome-screensaver" -#define GCONF_KEY  GCONF_DIR "/lock_enabled" +#define SCREENSAVER_SCHEMA            "org.gnome.desktop.screensaver" +#define SCREENSAVER_LOCK_ENABLED_KEY  "lock-enabled"  static DBusGProxy * gss_proxy = NULL;  static GMainLoop * gss_mainloop = NULL; @@ -34,7 +34,7 @@ static DBusGProxyCall * cookie_call = NULL;  static gboolean is_guest = FALSE; -static GConfClient * gconf_client = NULL; +static GSettings * settings = NULL;  void build_gss_proxy (void); @@ -131,11 +131,11 @@ will_lock_screen (void)  		return FALSE;  	} -	if (gconf_client == NULL) { -		gconf_client = gconf_client_get_default(); +	if (settings == NULL) { +		settings = g_settings_new (SCREENSAVER_SCHEMA);  	} -	return gconf_client_get_bool (gconf_client, GCONF_KEY, NULL); +	return g_settings_get_boolean (settings, SCREENSAVER_LOCK_ENABLED_KEY);  }  /* When the screensave go active, if we've got a mainloop @@ -150,11 +150,22 @@ gss_active_changed (DBusGProxy * proxy, gboolean active, gpointer data)  	return;  } +static gboolean +get_greeter_mode (void) +{ +	const gchar *var; +	var = g_getenv("INDICATOR_GREETER_MODE"); +	return (g_strcmp0(var, "1") == 0); +} +  /* Build the gss proxy and set up it's signals */  void  build_gss_proxy (void)  {  	if (gss_proxy == NULL) { +		if (get_greeter_mode ()) +			return; /* Don't start/lock the screensaver from the login screen */ +  		DBusGConnection * session_bus = dbus_g_bus_get(DBUS_BUS_SESSION, NULL);  		g_return_if_fail(session_bus != NULL); diff --git a/src/consolekit-manager.xml b/src/org.freedesktop.ConsoleKit.Manager.xml index f903b55..f903b55 100644 --- a/src/consolekit-manager.xml +++ b/src/org.freedesktop.ConsoleKit.Manager.xml diff --git a/src/org.freedesktop.ConsoleKit.Seat.xml b/src/org.freedesktop.ConsoleKit.Seat.xml new file mode 100644 index 0000000..d95990b --- /dev/null +++ b/src/org.freedesktop.ConsoleKit.Seat.xml @@ -0,0 +1,164 @@ +<?xml version="1.0" encoding="UTF-8"?> +<node xmlns:doc="http://www.freedesktop.org/dbus/1.0/doc.dtd"> + +  <interface name="org.freedesktop.ConsoleKit.Seat"> +    <doc:doc> +      <doc:description> +        <doc:para>A seat is a collection of sessions and a set of hardware (usually at +least a keyboard and mouse).  Only one session may be active on a +seat at a time.</doc:para> +      </doc:description> +    </doc:doc> + +    <method name="GetId"> +      <arg name="sid" direction="out" type="o"> +        <doc:doc> +          <doc:summary>Seat ID</doc:summary> +        </doc:doc> +      </arg> +      <doc:doc> +        <doc:description> +          <doc:para>Returns the ID for Seat.</doc:para> +        </doc:description> +      </doc:doc> +    </method> + +    <method name="GetSessions"> +      <arg name="sessions" direction="out" type="ao"> +        <doc:doc> +          <doc:summary>an array of Session IDs</doc:summary> +        </doc:doc> +      </arg> +      <doc:doc> +        <doc:description> +          <doc:para>This gets a list of all the <doc:ref type="interface" to="Session">Sessions</doc:ref> +          that are currently attached to this seat.</doc:para> +          <doc:para>Each Session ID is an D-Bus object path for the object that implements the +          <doc:ref type="interface" to="Session">Session</doc:ref> interface.</doc:para> +        </doc:description> +      </doc:doc> +    </method> + +    <method name="GetDevices"> +      <arg name="devices" direction="out" type="a(ss)"> +        <doc:doc> +          <doc:summary>an array of devices</doc:summary> +        </doc:doc> +      </arg> +      <doc:doc> +        <doc:description> +          <doc:para>This gets a list of all the devices +          that are currently associated with this seat.</doc:para> +          <doc:para>Each device is an D-Bus structure that represents +          the device type and the device id. +          </doc:para> +        </doc:description> +      </doc:doc> +    </method> + +    <method name="GetActiveSession"> +      <arg name="ssid" direction="out" type="o"> +        <doc:doc> +          <doc:summary>Session ID</doc:summary> +        </doc:doc> +      </arg> +      <doc:doc> +        <doc:description> +          <doc:para>Gets the Session ID that is currently active on this Seat.</doc:para> +          <doc:para>Returns NULL if there is no active session.</doc:para> +        </doc:description> +      </doc:doc> +    </method> + +    <method name="CanActivateSessions"> +      <arg name="can_activate" direction="out" type="b"> +        <doc:doc> +          <doc:summary>TRUE if seat supports session activation</doc:summary> +        </doc:doc> +      </arg> +      <doc:doc> +        <doc:description><doc:para>Used to determine whether the seat supports session activation.</doc:para> +        </doc:description> +      </doc:doc> +    </method> + +    <method name="ActivateSession"> +      <annotation name="org.freedesktop.DBus.GLib.Async" value=""/> +      <arg name="ssid" direction="in" type="o"> +        <doc:doc> +          <doc:summary>Session ID</doc:summary> +        </doc:doc> +      </arg> +      <doc:doc> +        <doc:description> +          <doc:para>Attempt to activate the specified session.  In most +          cases, if successful, this will cause the session to +          become visible and take control of the hardware that is +          associated with this seat.</doc:para> +        </doc:description> +        <doc:seealso><doc:ref type="method" to="Session.Activate">Activate()</doc:ref></doc:seealso> +      </doc:doc> +    </method> + +    <signal name="ActiveSessionChanged"> +      <arg name="ssid" type="o"> +        <doc:doc> +          <doc:summary>Session ID</doc:summary> +        </doc:doc> +      </arg> +      <doc:doc> +        <doc:description> +          <doc:para>Emitted when the active session has changed.</doc:para> +        </doc:description> +      </doc:doc> +    </signal> +    <signal name="SessionAdded"> +      <arg name="ssid" type="o"> +        <doc:doc> +          <doc:summary>Session ID</doc:summary> +        </doc:doc> +      </arg> +      <doc:doc> +        <doc:description> +          <doc:para>Emitted when a session has been added to the seat.</doc:para> +        </doc:description> +      </doc:doc> +    </signal> +    <signal name="SessionRemoved"> +      <arg name="ssid" type="o"> +        <doc:doc> +          <doc:summary>Session ID</doc:summary> +        </doc:doc> +      </arg> +      <doc:doc> +        <doc:description> +          <doc:para>Emitted when a session has been removed from the seat.</doc:para> +        </doc:description> +      </doc:doc> +    </signal> +    <signal name="DeviceAdded"> +      <arg name="device" type="(ss)"> +        <doc:doc> +          <doc:summary>Device structure</doc:summary> +        </doc:doc> +      </arg> +      <doc:doc> +        <doc:description> +          <doc:para>Emitted when a device has been associated with the seat.</doc:para> +        </doc:description> +      </doc:doc> +    </signal> +    <signal name="DeviceRemoved"> +      <arg name="device" type="(ss)"> +        <doc:doc> +          <doc:summary>Device structure</doc:summary> +        </doc:doc> +      </arg> +      <doc:doc> +        <doc:description> +          <doc:para>Emitted when a device has been dissociated from the seat.</doc:para> +        </doc:description> +      </doc:doc> +    </signal> +  </interface> +</node> diff --git a/src/consolekit-session.xml b/src/org.freedesktop.ConsoleKit.Session.xml index b6e1cdb..b6e1cdb 100644 --- a/src/consolekit-session.xml +++ b/src/org.freedesktop.ConsoleKit.Session.xml diff --git a/src/session-service.c b/src/session-service.c index fa212fd..753e304 100644 --- a/src/session-service.c +++ b/src/session-service.c @@ -118,7 +118,7 @@ main (int argc, char ** argv)    if (!greeter_mode) {      // Users -    UserMenuMgr* user_mgr = user_menu_mgr_new (session_dbus);     +    UserMenuMgr* user_mgr = user_menu_mgr_new (session_dbus, greeter_mode);          DbusmenuServer* users_server = dbusmenu_server_new (INDICATOR_USERS_DBUS_OBJECT);      dbusmenu_server_set_root (users_server, user_mgr_get_root_item (user_mgr));    } diff --git a/src/udev-mgr.c b/src/udev-mgr.c index e3328ec..f66d862 100644 --- a/src/udev-mgr.c +++ b/src/udev-mgr.c @@ -254,7 +254,7 @@ debug_device (UdevMgr* self,                GUdevDevice* device,                UdevMgrDeviceAction action)  { -  const gchar* vendor; +  /*const gchar* vendor;    const gchar* product;    const gchar* number;    const gchar* name; @@ -269,7 +269,7 @@ debug_device (UdevMgr* self,             g_strdup(product),             g_strdup(number),             g_strdup(name)); -            +             const gchar *const *list;    const gchar *const *iter;      char propstr[500]; @@ -290,7 +290,7 @@ debug_device (UdevMgr* self,             strcat(propstr, " ");      strcat(propstr, g_udev_device_get_property(device, *iter));      g_debug("%s", propstr); -  }    +  }*/    }  static void udev_mgr_handle_scsi_device (UdevMgr* self, diff --git a/src/user-menu-mgr.c b/src/user-menu-mgr.c index bf3b77f..72b5802 100644 --- a/src/user-menu-mgr.c +++ b/src/user-menu-mgr.c @@ -49,13 +49,19 @@ static gint compare_users_by_username (const gchar *a,  static void activate_online_accounts (DbusmenuMenuitem *mi,                                        guint timestamp,                                        gpointer user_data); -static void user_menu_mgr_rebuild_items (UserMenuMgr *self); +static void user_menu_mgr_rebuild_items (UserMenuMgr *self, +                                         gboolean greeter_mode);  static gboolean check_new_session ();  static void user_change (UsersServiceDbus *service,                           const gchar      *user_id,                           gpointer          user_data);  static void ensure_gconf_client (); +static gboolean check_guest_session (void); +static void activate_guest_session (DbusmenuMenuitem * mi, +                                    guint timestamp, +                                    gpointer user_data); +  G_DEFINE_TYPE (UserMenuMgr, user_menu_mgr, G_TYPE_OBJECT); @@ -93,7 +99,7 @@ user_menu_mgr_class_init (UserMenuMgrClass *klass)  /* Builds up the menu for us */  static void  -user_menu_mgr_rebuild_items (UserMenuMgr *self) +user_menu_mgr_rebuild_items (UserMenuMgr *self, gboolean greeter_mode)  {    DbusmenuMenuitem *mi = NULL;    DbusmenuMenuitem *guest_mi = NULL; @@ -121,6 +127,7 @@ user_menu_mgr_rebuild_items (UserMenuMgr *self)    /* Build all of the user switching items */    if (can_activate == TRUE)    { +          if (check_new_session ()){        switch_menuitem = dbusmenu_menuitem_new ();        dbusmenu_menuitem_property_set (switch_menuitem, @@ -134,14 +141,41 @@ user_menu_mgr_rebuild_items (UserMenuMgr *self)                          DBUSMENU_MENUITEM_SIGNAL_ITEM_ACTIVATED,                          G_CALLBACK (activate_new_session),                          self->users_dbus_interface); +    }     +     +    if (check_guest_session ()) +    { +      guest_mi = dbusmenu_menuitem_new (); +      dbusmenu_menuitem_property_set (guest_mi, +                                      DBUSMENU_MENUITEM_PROP_TYPE, +                                      USER_ITEM_TYPE); +      dbusmenu_menuitem_property_set (guest_mi, +                                      USER_ITEM_PROP_NAME, +                                      _("Guest Session")); +      dbusmenu_menuitem_property_set_bool (guest_mi, +                                           USER_ITEM_PROP_LOGGED_IN, +                                           FALSE); +      dbusmenu_menuitem_child_append (self->root_item, guest_mi); +      g_signal_connect (G_OBJECT (guest_mi), +                        DBUSMENU_MENUITEM_SIGNAL_ITEM_ACTIVATED, +                        G_CALLBACK (activate_guest_session), +                        self); +      users_service_dbus_set_guest_item (self->users_dbus_interface, +                                         guest_mi);      } - +          GList * users = NULL;      users = users_service_dbus_get_user_list (self->users_dbus_interface);      self->user_count = g_list_length(users); -    g_debug ("USER COUNT = %i", self->user_count); -    session_dbus_set_user_menu_visibility (self->session_dbus_interface, self->user_count > 1); +    gboolean user_menu_is_visible = FALSE; +     +    if (!greeter_mode){ +      user_menu_is_visible = self->user_count > 1; +    } +     +    session_dbus_set_user_menu_visibility (self->session_dbus_interface, +                                           user_menu_is_visible);      if (self->user_count > MINIMUM_USERS && self->user_count < MAXIMUM_USERS) {        users = g_list_sort (users, (GCompareFunc)compare_users_by_username); @@ -354,15 +388,43 @@ user_mgr_get_root_item (UserMenuMgr* self)    return self->root_item;  } +/* Checks to see if we should show the guest suession item */ +static gboolean +check_guest_session (void) +{ +	if (geteuid() < 500) { +		/* System users shouldn't have guest account shown.  Mosly +		   this would be the case of the guest user itself. */ +		return FALSE; +	} + +	return TRUE; +} + +/* Called when someone clicks on the guest session item. */ +static void +activate_guest_session (DbusmenuMenuitem * mi, guint timestamp, gpointer user_data) +{ +  g_return_if_fail (USER_IS_MENU_MGR (user_data));   +  UserMenuMgr* user_mgr = USER_MENU_MGR(user_data);   +  UsersServiceDbus *service = user_mgr->users_dbus_interface; + +	lock_if_possible(); +   +  if (users_service_dbus_activate_guest_session(service)) { +    return; +  } +} +  /*   * Clean Entry Point    */ -UserMenuMgr* user_menu_mgr_new (SessionDbus* session_dbus) +UserMenuMgr* user_menu_mgr_new (SessionDbus* session_dbus, gboolean greeter_mode)  {    UserMenuMgr* user_mgr = g_object_new (USER_TYPE_MENU_MGR, NULL);    user_mgr->session_dbus_interface = session_dbus; -  user_menu_mgr_rebuild_items (user_mgr);     +  user_menu_mgr_rebuild_items (user_mgr, greeter_mode);        return user_mgr;  } diff --git a/src/user-menu-mgr.h b/src/user-menu-mgr.h index ff2cb77..01823e7 100644 --- a/src/user-menu-mgr.h +++ b/src/user-menu-mgr.h @@ -45,7 +45,8 @@ struct _UserMenuMgrClass  };  GType user_menu_mgr_get_type (void) G_GNUC_CONST; -UserMenuMgr* user_menu_mgr_new (SessionDbus* session_dbus); +UserMenuMgr* user_menu_mgr_new (SessionDbus* session_dbus, +                                gboolean greeter_mode);  DbusmenuMenuitem* user_mgr_get_root_item (UserMenuMgr* self);  G_END_DECLS diff --git a/src/user-widget.c b/src/user-widget.c index 9b046c5..6495e80 100644 --- a/src/user-widget.c +++ b/src/user-widget.c @@ -126,8 +126,6 @@ user_widget_init (UserWidget *self)    priv->user_name = gtk_label_new ("");    priv->container = gtk_hbox_new (FALSE, 0); -  // TODO:  -  // Delete tick icon and draw primitively.  	priv->tick_icon = gtk_image_new_from_icon_name ("account-logged-in",                                                     GTK_ICON_SIZE_MENU);   	gtk_misc_set_alignment(GTK_MISC(priv->tick_icon), 1.0, 0.5); @@ -151,6 +149,10 @@ user_widget_init (UserWidget *self)    gtk_widget_show_all (priv->container);    gtk_container_add (GTK_CONTAINER (self), priv->container);   +  gtk_widget_show_all (priv->tick_icon); +  gtk_widget_set_no_show_all (priv->tick_icon, TRUE); +  gtk_widget_hide (priv->tick_icon); +      // Fetch the drawing context.    #if GTK_CHECK_VERSION(3, 0, 0)     g_signal_connect_after (GTK_WIDGET(self), "draw",  @@ -178,11 +180,6 @@ user_widget_finalize (GObject *object)    G_OBJECT_CLASS (user_widget_parent_class)->finalize (object);  } -/** - * We override the expose method to enable primitive drawing of the  - * empty album art image and rounded rectangles on the album art. - */ -  #if GTK_CHECK_VERSION(3, 0, 0)    // Draw the radio dot and/or green check mark @@ -317,11 +314,16 @@ user_widget_set_twin_item (UserWidget* self,    gtk_label_set_label (GTK_LABEL (priv->user_name),                         dbusmenu_menuitem_property_get (twin_item, USER_ITEM_PROP_NAME)); -	//if (dbusmenu_menuitem_property_get_bool (twin_item, USER_ITEM_PROP_LOGGED_IN)) { -	//	gtk_widget_show(priv->tick_icon); -	//} else { -  gtk_widget_show(priv->tick_icon); -	//} +	if (dbusmenu_menuitem_property_get_bool (twin_item, USER_ITEM_PROP_LOGGED_IN)) { +    g_debug ("%s USER HAS ACTIVE SESSIONS",  +             dbusmenu_menuitem_property_get (twin_item, USER_ITEM_PROP_NAME)); +	  gtk_widget_show(priv->tick_icon); +	} +  else { +    g_debug ("%s USER DOESN'T HAVE ACTIVE SESSIONS",  +             dbusmenu_menuitem_property_get (twin_item, USER_ITEM_PROP_NAME)); +    gtk_widget_hide(priv->tick_icon); +	}  	g_debug("Using user icon for '%s' from file: %s",            dbusmenu_menuitem_property_get(twin_item, USER_ITEM_PROP_NAME), icon_name); diff --git a/src/users-service-dbus.c b/src/users-service-dbus.c index 83edaa3..e7507a4 100644 --- a/src/users-service-dbus.c +++ b/src/users-service-dbus.c @@ -36,6 +36,7 @@  #include "accounts-service-client.h"  #include "consolekit-manager-client.h"  #include "consolekit-session-client.h" +#include "consolekit-seat-client.h"  #define CK_ADDR             "org.freedesktop.ConsoleKit"  #define CK_SESSION_IFACE    "org.freedesktop.ConsoleKit.Session" @@ -315,6 +316,28 @@ create_ck_proxy (UsersServiceDbus *self)      }  } +/* Get the initial sessions when starting up */ +static void  +get_cksessions_cb (DBusGProxy *proxy, GPtrArray * sessions, GError * error, gpointer userdata) +{ +	if (error != NULL) { +		g_warning("Unable to get initial sessions: %s", error->message); +		return; +	} + +	/* If there's no error we should at least get an +	   array of zero entries */ +	g_return_if_fail(sessions != NULL); +	g_debug("Got %d initial sessions", sessions->len); + +	int i; +	for (i = 0; i < sessions->len; i++) { +		seat_proxy_session_added(proxy, g_ptr_array_index(sessions, i), USERS_SERVICE_DBUS(userdata)); +	} + +	return; +} +  static void  create_seat_proxy (UsersServiceDbus *self)  { @@ -363,6 +386,10 @@ create_seat_proxy (UsersServiceDbus *self)                                 G_CALLBACK (seat_proxy_session_removed),                                 self,                                 NULL); + +  org_freedesktop_ConsoleKit_Seat_get_sessions_async (priv->seat_proxy, get_cksessions_cb, self); + +  return;  }  static void @@ -556,7 +583,11 @@ static void  add_sessions_for_user (UsersServiceDbus *self,                         UserData         *user)  { -  g_return_if_fail(IS_USERS_SERVICE_DBUS(self)); +  g_return_if_fail (IS_USERS_SERVICE_DBUS(self)); + +  g_debug ("!!!!!!!!!! - add_sessions_for_user %i %s", +          (int)user->uid, user->user_name); +    UsersServiceDbusPrivate *priv = USERS_SERVICE_DBUS_GET_PRIVATE (self);    GError          *error;    GPtrArray       *sessions; | 
