Blame SOURCES/0003-daemon-save-os-release-in-accountsservice.patch

0cfcbe
From de95917e0e9d142703a86f94961ef9fd4151739d Mon Sep 17 00:00:00 2001
f83012
From: Ray Strode <rstrode@redhat.com>
f83012
Date: Mon, 20 Aug 2018 14:30:59 -0400
18ca79
Subject: [PATCH 3/4] daemon: save os-release in accountsservice
f83012
f83012
It can be useful to know what OS a user was running
f83012
when they logged in (to detect upgrades).
f83012
f83012
This commit saves that information in accountsservice.
f83012
---
f83012
 .../com.redhat.AccountsServiceUser.System.xml | 10 ++
ffa191
 daemon/gdm-session-settings.c                 | 98 +++++++++++++++++++
18ca79
 daemon/gdm-session.c                          |  4 +-
ffa191
 daemon/meson.build                            |  8 ++
18ca79
 4 files changed, 118 insertions(+), 2 deletions(-)
ffa191
 create mode 100644 daemon/com.redhat.AccountsServiceUser.System.xml
f83012
ffa191
diff --git a/daemon/com.redhat.AccountsServiceUser.System.xml b/daemon/com.redhat.AccountsServiceUser.System.xml
ffa191
new file mode 100644
3b7bb8
index 00000000..67f5f302
ffa191
--- /dev/null
ffa191
+++ b/daemon/com.redhat.AccountsServiceUser.System.xml
ffa191
@@ -0,0 +1,10 @@
ffa191
+<node>
ffa191
+  <interface name="com.redhat.AccountsServiceUser.System">
f83012
+
ffa191
+    <annotation name="org.freedesktop.Accounts.VendorExtension" value="true"/>
ffa191
+
ffa191
+    <property name="id" type="s" access="readwrite"/>
ffa191
+    <property name="version-id" type="s" access="readwrite"/>
ffa191
+
ffa191
+  </interface>
ffa191
+</node>
f83012
diff --git a/daemon/gdm-session-settings.c b/daemon/gdm-session-settings.c
3b7bb8
index f2b1addd..a4b7f1a6 100644
f83012
--- a/daemon/gdm-session-settings.c
f83012
+++ b/daemon/gdm-session-settings.c
f83012
@@ -1,70 +1,77 @@
f83012
 /* gdm-session-settings.c - Loads session and language from ~/.dmrc
f83012
  *
f83012
  * Copyright (C) 2008 Red Hat, Inc.
f83012
  *
f83012
  * This program is free software; you can redistribute it and/or modify
f83012
  * it under the terms of the GNU General Public License as published by
f83012
  * the Free Software Foundation; either version 2, or (at your option)
f83012
  * any later version.
f83012
  *
f83012
  * This program is distributed in the hope that it will be useful,
f83012
  * but WITHOUT ANY WARRANTY; without even the implied warranty of
f83012
  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
f83012
  * GNU General Public License for more details.
f83012
  *
f83012
  * You should have received a copy of the GNU General Public License
f83012
  * along with this program; if not, write to the Free Software
f83012
  * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA
f83012
  * 02110-1301, USA.
f83012
  *
f83012
  * Written by: Ray Strode <rstrode@redhat.com>
f83012
  */
f83012
 #include "config.h"
f83012
 #include "gdm-session-settings.h"
f83012
+#include "gdm-common.h"
f83012
+
f83012
+#include "com.redhat.AccountsServiceUser.System.h"
f83012
 
f83012
 #include <errno.h>
f83012
 #include <pwd.h>
f83012
 #include <string.h>
f83012
 #include <sys/types.h>
f83012
 #include <unistd.h>
f83012
 
f83012
 #include <glib.h>
f83012
 #include <glib-object.h>
f83012
 #include <glib/gi18n.h>
f83012
 
f83012
 #include <act/act-user-manager.h>
f83012
 
f83012
 struct _GdmSessionSettingsPrivate
f83012
 {
f83012
         ActUserManager *user_manager;
f83012
         ActUser *user;
f83012
+
f83012
+        /* used for retrieving the last OS user logged in with */
f83012
+        GdmAccountsServiceUserSystem *user_system_proxy;
f83012
+
f83012
         char *session_name;
f83012
         char *session_type;
f83012
         char *language_name;
f83012
 };
f83012
 
f83012
 static void gdm_session_settings_finalize (GObject *object);
f83012
 static void gdm_session_settings_class_install_properties (GdmSessionSettingsClass *
f83012
                                               settings_class);
f83012
 
f83012
 static void gdm_session_settings_set_property (GObject      *object,
f83012
                                               guint         prop_id,
f83012
                                               const GValue *value,
f83012
                                               GParamSpec   *pspec);
f83012
 static void gdm_session_settings_get_property (GObject      *object,
f83012
                                               guint         prop_id,
f83012
                                               GValue       *value,
f83012
                                               GParamSpec   *pspec);
f83012
 
f83012
 enum {
f83012
         PROP_0 = 0,
f83012
         PROP_SESSION_NAME,
f83012
         PROP_SESSION_TYPE,
f83012
         PROP_LANGUAGE_NAME,
f83012
         PROP_IS_LOADED
f83012
 };
f83012
 
ffa191
 G_DEFINE_TYPE_WITH_PRIVATE (GdmSessionSettings,
ffa191
                             gdm_session_settings,
ffa191
                             G_TYPE_OBJECT)
f83012
 
f83012
@@ -107,60 +114,62 @@ gdm_session_settings_class_install_properties (GdmSessionSettingsClass *settings
f83012
         g_object_class_install_property (object_class, PROP_LANGUAGE_NAME, param_spec);
f83012
 
f83012
         param_spec = g_param_spec_boolean ("is-loaded", NULL, NULL,
ffa191
                                            FALSE, G_PARAM_READABLE | G_PARAM_STATIC_STRINGS);
f83012
         g_object_class_install_property (object_class, PROP_IS_LOADED, param_spec);
f83012
 }
f83012
 
f83012
 static void
f83012
 gdm_session_settings_init (GdmSessionSettings *settings)
f83012
 {
f83012
         settings->priv = G_TYPE_INSTANCE_GET_PRIVATE (settings,
f83012
                                                      GDM_TYPE_SESSION_SETTINGS,
f83012
                                                      GdmSessionSettingsPrivate);
f83012
 
f83012
         settings->priv->user_manager = act_user_manager_get_default ();
f83012
 
f83012
 }
f83012
 
f83012
 static void
f83012
 gdm_session_settings_finalize (GObject *object)
f83012
 {
f83012
         GdmSessionSettings *settings;
f83012
         GObjectClass *parent_class;
f83012
 
f83012
         settings = GDM_SESSION_SETTINGS (object);
f83012
 
f83012
         if (settings->priv->user != NULL) {
f83012
                 g_object_unref (settings->priv->user);
f83012
         }
f83012
 
f83012
+        g_clear_object (&settings->priv->user_system_proxy);
f83012
+
f83012
         g_free (settings->priv->session_name);
f83012
         g_free (settings->priv->language_name);
f83012
 
f83012
         parent_class = G_OBJECT_CLASS (gdm_session_settings_parent_class);
f83012
 
f83012
         if (parent_class->finalize != NULL) {
f83012
                 parent_class->finalize (object);
f83012
         }
f83012
 }
f83012
 
f83012
 void
f83012
 gdm_session_settings_set_language_name (GdmSessionSettings *settings,
f83012
                                         const char         *language_name)
f83012
 {
f83012
         g_return_if_fail (GDM_IS_SESSION_SETTINGS (settings));
f83012
 
f83012
         if (settings->priv->language_name == NULL ||
f83012
             strcmp (settings->priv->language_name, language_name) != 0) {
f83012
                 settings->priv->language_name = g_strdup (language_name);
f83012
                 g_object_notify (G_OBJECT (settings), "language-name");
f83012
         }
f83012
 }
f83012
 
f83012
 void
f83012
 gdm_session_settings_set_session_name (GdmSessionSettings *settings,
f83012
                                        const char         *session_name)
f83012
 {
f83012
         g_return_if_fail (GDM_IS_SESSION_SETTINGS (settings));
f83012
 
f83012
         if (settings->priv->session_name == NULL ||
f83012
@@ -261,69 +270,86 @@ gdm_session_settings_get_property (GObject    *object,
f83012
 
f83012
                 default:
f83012
                         G_OBJECT_WARN_INVALID_PROPERTY_ID (object, prop_id, pspec);
f83012
     }
f83012
 }
f83012
 
f83012
 GdmSessionSettings *
f83012
 gdm_session_settings_new (void)
f83012
 {
f83012
         GdmSessionSettings *settings;
f83012
 
f83012
         settings = g_object_new (GDM_TYPE_SESSION_SETTINGS,
f83012
                                  NULL);
f83012
 
f83012
         return settings;
f83012
 }
f83012
 
f83012
 gboolean
f83012
 gdm_session_settings_is_loaded (GdmSessionSettings  *settings)
f83012
 {
f83012
         if (settings->priv->user == NULL) {
f83012
                 return FALSE;
f83012
         }
f83012
 
f83012
         return act_user_is_loaded (settings->priv->user);
f83012
 }
f83012
 
f83012
 static void
f83012
 load_settings_from_user (GdmSessionSettings *settings)
f83012
 {
f83012
+        const char *object_path;
f83012
         const char *session_name;
f83012
         const char *session_type;
f83012
         const char *language_name;
f83012
 
f83012
         if (!act_user_is_loaded (settings->priv->user)) {
f83012
                 g_warning ("GdmSessionSettings: trying to load user settings from unloaded user");
f83012
                 return;
f83012
         }
f83012
 
f83012
+        object_path = act_user_get_object_path (settings->priv->user);
f83012
+
f83012
+        if (object_path != NULL) {
f83012
+                g_autoptr (GError) error = NULL;
f83012
+                settings->priv->user_system_proxy = gdm_accounts_service_user_system_proxy_new_for_bus_sync (G_BUS_TYPE_SYSTEM,
f83012
+                                                                                                             G_DBUS_PROXY_FLAGS_NONE,
f83012
+                                                                                                             "org.freedesktop.Accounts",
f83012
+                                                                                                             object_path,
f83012
+                                                                                                             NULL,
f83012
+                                                                                                             &error);
f83012
+                if (error != NULL) {
f83012
+                        g_debug ("GdmSessionSettings: couldn't retrieve user system proxy from accountsservice: %s",
f83012
+                                 error->message);
f83012
+                }
f83012
+        }
f83012
+
3b7bb8
 
3b7bb8
 
3b7bb8
 
f83012
 
f83012
         session_type = act_user_get_session_type (settings->priv->user);
f83012
         session_name = act_user_get_session (settings->priv->user);
f83012
 
f83012
         g_debug ("GdmSessionSettings: saved session is %s (type %s)", session_name, session_type);
f83012
 
f83012
         if (session_type != NULL && session_type[0] != '\0') {
f83012
                 gdm_session_settings_set_session_type (settings, session_type);
f83012
         }
f83012
 
f83012
         if (session_name != NULL && session_name[0] != '\0') {
f83012
                 gdm_session_settings_set_session_name (settings, session_name);
f83012
         }
f83012
 
f83012
         language_name = act_user_get_language (settings->priv->user);
f83012
 
f83012
         g_debug ("GdmSessionSettings: saved language is %s", language_name);
f83012
         if (language_name != NULL && language_name[0] != '\0') {
f83012
                 gdm_session_settings_set_language_name (settings, language_name);
f83012
         }
f83012
 
f83012
 out:
f83012
         g_object_notify (G_OBJECT (settings), "is-loaded");
f83012
 }
f83012
 
f83012
 static void
f83012
 on_user_is_loaded_changed (ActUser            *user,
f83012
@@ -349,64 +375,136 @@ gdm_session_settings_load (GdmSessionSettings  *settings,
f83012
         g_return_val_if_fail (!gdm_session_settings_is_loaded (settings), FALSE);
f83012
 
f83012
         if (settings->priv->user != NULL) {
f83012
                 old_user = settings->priv->user;
f83012
 
f83012
                 g_signal_handlers_disconnect_by_func (G_OBJECT (settings->priv->user),
f83012
                                                       G_CALLBACK (on_user_is_loaded_changed),
f83012
                                                       settings);
f83012
         } else {
f83012
                 old_user = NULL;
f83012
         }
f83012
 
f83012
         settings->priv->user = act_user_manager_get_user (settings->priv->user_manager,
f83012
                                                           username);
f83012
 
f83012
         g_clear_object (&old_user);
f83012
 
f83012
         if (!act_user_is_loaded (settings->priv->user)) {
f83012
                 g_signal_connect (settings->priv->user,
f83012
                                   "notify::is-loaded",
f83012
                                   G_CALLBACK (on_user_is_loaded_changed),
f83012
                                   settings);
f83012
                 return FALSE;
f83012
         }
f83012
 
f83012
         load_settings_from_user (settings);
f83012
 
f83012
         return TRUE;
f83012
 }
f83012
 
f83012
+static void
f83012
+save_os_release (GdmSessionSettings *settings,
f83012
+                 ActUser            *user)
f83012
+{
f83012
+        g_autoptr(GFile) file = NULL;
f83012
+        g_autoptr(GError) error = NULL;
f83012
+        g_autofree char *contents = NULL;
f83012
+        g_auto(GStrv) lines = NULL;
f83012
+        size_t i;
f83012
+
f83012
+        if (settings->priv->user_system_proxy == NULL) {
f83012
+                g_debug ("GdmSessionSettings: not saving OS version to user account because accountsservice doesn't support it");
f83012
+                return;
f83012
+        }
f83012
+
f83012
+        file = g_file_new_for_path ("/etc/os-release");
f83012
+
f83012
+        if (!g_file_load_contents (file, NULL, &contents, NULL, NULL, &error)) {
f83012
+                g_debug ("GdmSessionSettings: couldn't load /etc/os-release: %s", error->message);
f83012
+                return;
f83012
+        }
f83012
+
f83012
+        lines = g_strsplit (contents, "\n", -1);
f83012
+        for (i = 0; lines[i] != NULL; i++) {
f83012
+                char *p, *name, *name_end, *value, *value_end;
f83012
+
f83012
+                p = lines[i];
f83012
+
f83012
+                while (g_ascii_isspace (*p))
f83012
+                        p++;
f83012
+
f83012
+                if (*p == '#' || *p == '\0')
f83012
+                        continue;
f83012
+                name = p;
f83012
+                while (gdm_shell_var_is_valid_char (*p, p == name))
f83012
+                        p++;
f83012
+                name_end = p;
f83012
+                while (g_ascii_isspace (*p))
f83012
+                        p++;
f83012
+                if (name == name_end || *p != '=') {
f83012
+                        continue;
f83012
+                }
f83012
+                *name_end = '\0';
f83012
+
f83012
+                p++;
f83012
+
f83012
+                while (g_ascii_isspace (*p))
f83012
+                        p++;
f83012
+
f83012
+                value = p;
f83012
+                value_end = value + strlen(value) - 1;
f83012
+
f83012
+                if (value != value_end && *value == '"' && *value_end == '"') {
f83012
+                        value++;
f83012
+                        *value_end = '\0';
f83012
+                }
f83012
+
f83012
+                if (strcmp (name, "ID") == 0) {
f83012
+                        gdm_accounts_service_user_system_set_id (settings->priv->user_system_proxy,
f83012
+                                                                 value);
f83012
+                        g_debug ("GdmSessionSettings: setting system OS for user to '%s'", value);
f83012
+                } else if (strcmp (name, "VERSION_ID") == 0) {
f83012
+                        gdm_accounts_service_user_system_set_version_id (settings->priv->user_system_proxy,
f83012
+                                                                         value);
f83012
+                        g_debug ("GdmSessionSettings: setting system OS version for user to '%s'", value);
f83012
+                }
f83012
+        }
f83012
+}
f83012
+
f83012
 gboolean
f83012
 gdm_session_settings_save (GdmSessionSettings  *settings,
f83012
                            const char          *username)
f83012
 {
f83012
         ActUser  *user;
f83012
 
f83012
         g_return_val_if_fail (GDM_IS_SESSION_SETTINGS (settings), FALSE);
f83012
         g_return_val_if_fail (username != NULL, FALSE);
f83012
         g_return_val_if_fail (gdm_session_settings_is_loaded (settings), FALSE);
f83012
 
f83012
         user = act_user_manager_get_user (settings->priv->user_manager,
f83012
                                           username);
f83012
 
f83012
 
f83012
         if (!act_user_is_loaded (user)) {
f83012
                 g_object_unref (user);
f83012
                 return FALSE;
f83012
         }
f83012
 
f83012
         if (settings->priv->session_name != NULL) {
f83012
                 act_user_set_session (user, settings->priv->session_name);
f83012
         }
f83012
 
f83012
         if (settings->priv->session_type != NULL) {
f83012
                 act_user_set_session_type (user, settings->priv->session_type);
f83012
         }
f83012
 
f83012
         if (settings->priv->language_name != NULL) {
f83012
                 act_user_set_language (user, settings->priv->language_name);
f83012
         }
f83012
+
f83012
+        save_os_release (settings, user);
f83012
+
f83012
         g_object_unref (user);
f83012
 
f83012
         return TRUE;
f83012
 }
18ca79
diff --git a/daemon/gdm-session.c b/daemon/gdm-session.c
0cfcbe
index f4d0bef9..d1e2c301 100644
18ca79
--- a/daemon/gdm-session.c
18ca79
+++ b/daemon/gdm-session.c
18ca79
@@ -351,72 +351,72 @@ supports_session_type (GdmSession *self,
18ca79
         if (session_type == NULL)
18ca79
                 return TRUE;
18ca79
 
18ca79
         return g_strv_contains ((const char * const *) self->supported_session_types,
18ca79
                                 session_type);
18ca79
 }
18ca79
 
18ca79
 static char **
18ca79
 get_system_session_dirs (GdmSession *self,
18ca79
                          const char *type)
18ca79
 {
18ca79
         GArray *search_array = NULL;
18ca79
         char **search_dirs;
18ca79
         int i, j;
18ca79
         const gchar * const *system_data_dirs = g_get_system_data_dirs ();
18ca79
 
18ca79
         static const char *x_search_dirs[] = {
18ca79
                 "/etc/X11/sessions/",
18ca79
                 DMCONFDIR "/Sessions/",
18ca79
                 DATADIR "/gdm/BuiltInSessions/",
18ca79
                 DATADIR "/xsessions/",
18ca79
         };
18ca79
 
18ca79
         static const char *wayland_search_dir = DATADIR "/wayland-sessions/";
18ca79
 
18ca79
         search_array = g_array_new (TRUE, TRUE, sizeof (char *));
18ca79
 
18ca79
         for (j = 0; self->supported_session_types[j] != NULL; j++) {
18ca79
                 const char *supported_type = self->supported_session_types[j];
18ca79
 
18ca79
-                if (g_str_equal (supported_type, "x11") ||
18ca79
+                if (g_str_equal (supported_type, "x11") &&
18ca79
                     (type == NULL || g_str_equal (type, supported_type))) {
18ca79
                         for (i = 0; system_data_dirs[i]; i++) {
18ca79
                                 gchar *dir = g_build_filename (system_data_dirs[i], "xsessions", NULL);
18ca79
                                 g_array_append_val (search_array, dir);
18ca79
                         }
18ca79
 
18ca79
                         g_array_append_vals (search_array, x_search_dirs, G_N_ELEMENTS (x_search_dirs));
18ca79
                 }
18ca79
 
18ca79
 #ifdef ENABLE_WAYLAND_SUPPORT
18ca79
-                if (g_str_equal (supported_type, "wayland") ||
18ca79
+                if (g_str_equal (supported_type, "wayland") &&
18ca79
                     (type == NULL || g_str_equal (type, supported_type))) {
18ca79
                         for (i = 0; system_data_dirs[i]; i++) {
18ca79
                                 gchar *dir = g_build_filename (system_data_dirs[i], "wayland-sessions", NULL);
18ca79
                                 g_array_append_val (search_array, dir);
18ca79
                         }
18ca79
 
18ca79
                         g_array_append_val (search_array, wayland_search_dir);
18ca79
                 }
18ca79
 #endif
18ca79
         }
18ca79
 
18ca79
         search_dirs = g_strdupv ((char **) search_array->data);
18ca79
 
18ca79
         g_array_free (search_array, TRUE);
18ca79
 
18ca79
         return search_dirs;
18ca79
 }
18ca79
 
18ca79
 static gboolean
18ca79
 is_prog_in_path (const char *prog)
18ca79
 {
18ca79
         char    *f;
18ca79
         gboolean ret;
18ca79
 
18ca79
         f = g_find_program_in_path (prog);
18ca79
         ret = (f != NULL);
18ca79
         g_free (f);
18ca79
         return ret;
18ca79
 }
18ca79
 
ffa191
diff --git a/daemon/meson.build b/daemon/meson.build
3b7bb8
index 2e61b644..71c65039 100644
ffa191
--- a/daemon/meson.build
ffa191
+++ b/daemon/meson.build
ffa191
@@ -15,114 +15,122 @@ local_display_dbus_gen = gnome.gdbus_codegen('gdm-local-display-glue',
ffa191
   'gdm-local-display.xml',
ffa191
   namespace: 'GdmDBus',
ffa191
   interface_prefix: 'org.gnome.DisplayManager',
ffa191
   autocleanup: 'all',
ffa191
 )
ffa191
 local_display_factory_dbus_gen = gnome.gdbus_codegen('gdm-local-display-factory-glue',
ffa191
   'gdm-local-display-factory.xml',
ffa191
   namespace: 'GdmDBus',
ffa191
   interface_prefix: 'org.gnome.DisplayManager',
ffa191
   autocleanup: 'all',
ffa191
 )
ffa191
 manager_dbus_gen = gnome.gdbus_codegen('gdm-manager-glue',
ffa191
   'gdm-manager.xml',
ffa191
   namespace: 'GdmDBus',
ffa191
   interface_prefix: 'org.gnome.DisplayManager',
ffa191
   autocleanup: 'all',
ffa191
 )
ffa191
 session_dbus_gen = gnome.gdbus_codegen('gdm-session-glue',
ffa191
   'gdm-session.xml',
ffa191
   namespace: 'GdmDBus',
ffa191
   interface_prefix: 'org.gnome.DisplayManager',
ffa191
   autocleanup: 'all',
ffa191
 )
ffa191
 session_worker_dbus_gen = gnome.gdbus_codegen('gdm-session-worker-glue',
ffa191
   'gdm-session-worker.xml',
ffa191
   namespace: 'GdmDBus',
ffa191
   interface_prefix: 'org.gnome.DisplayManager',
ffa191
   autocleanup: 'all',
ffa191
 )
ffa191
 
ffa191
+accountsservice_system_user_dbus_gen = gnome.gdbus_codegen('com.redhat.AccountsServiceUser.System',
ffa191
+  'com.redhat.AccountsServiceUser.System.xml',
ffa191
+  namespace: 'Gdm',
ffa191
+  interface_prefix: 'com.redhat',
ffa191
+  autocleanup: 'all',
ffa191
+)
f83012
+
ffa191
 gdm_session_enums = gnome.mkenums('gdm-session-enum-types',
ffa191
   h_template: 'gdm-session-enum-types.h.in',
ffa191
   c_template: 'gdm-session-enum-types.c.in',
ffa191
   sources: 'gdm-session.h',
ffa191
 )
ffa191
 gdm_session_worker_enums = gnome.mkenums('gdm-session-worker-enum-types',
ffa191
   h_template: 'gdm-session-worker-enum-types.h.in',
ffa191
   c_template: 'gdm-session-worker-enum-types.c.in',
ffa191
   sources: 'gdm-session-worker.h',
ffa191
 )
ffa191
 
ffa191
 # Daemons deps
ffa191
 gdm_daemon_deps = [
ffa191
   libgdmcommon_dep,
ffa191
   accountsservice_dep,
ffa191
   gobject_dep,
ffa191
   gio_dep,
ffa191
   gio_unix_dep,
ffa191
   libpam_dep,
ffa191
   x_deps,
ffa191
   xcb_dep,
ffa191
 ]
ffa191
 
ffa191
 if xdmcp_dep.found() and get_option('tcp-wrappers')
ffa191
   gdm_daemon_deps += libwrap_dep
ffa191
 endif
ffa191
 
ffa191
 # test-session-client
ffa191
 test_session_client_src = [
ffa191
   'test-session-client.c',
ffa191
   session_dbus_gen,
ffa191
   manager_dbus_gen,
ffa191
 ]
ffa191
 
ffa191
 test_session_client = executable('test-session-client',
ffa191
   test_session_client_src,
ffa191
   dependencies: gdm_daemon_deps,
ffa191
   include_directories: config_h_dir,
ffa191
 )
ffa191
 
ffa191
 # Session worker
ffa191
 gdm_session_worker_src = [
ffa191
   'session-worker-main.c',
ffa191
   'gdm-session.c',
ffa191
   'gdm-session-settings.c',
ffa191
   'gdm-session-auditor.c',
ffa191
   'gdm-session-record.c',
ffa191
   'gdm-session-worker.c',
ffa191
   'gdm-session-worker-job.c',
ffa191
   'gdm-session-worker-common.c',
ffa191
   'gdm-dbus-util.c',
ffa191
   dbus_gen,
ffa191
   session_dbus_gen,
ffa191
   session_worker_dbus_gen,
ffa191
+  accountsservice_system_user_dbus_gen,
ffa191
   gdm_session_enums,
ffa191
   gdm_session_worker_enums,
ffa191
 ]
ffa191
 
ffa191
 gdm_session_worker_deps = [
ffa191
   gdm_daemon_deps,
ffa191
 ]
ffa191
 
ffa191
 gdm_session_worker_includes = [
ffa191
   config_h_dir,
ffa191
 ]
ffa191
 
ffa191
 if pam_extensions_supported
ffa191
   gdm_session_worker_src += '../pam-extensions/gdm-pam-extensions.h'
ffa191
   gdm_session_worker_includes += pam_extensions_inc
ffa191
 endif
ffa191
 
ffa191
 if libaudit_dep.found()
ffa191
   gdm_session_worker_deps += libaudit_dep
ffa191
 
ffa191
   gdm_session_worker_src += [
ffa191
     'gdm-session-linux-auditor.c',
ffa191
   ]
ffa191
 endif
ffa191
 
ffa191
 if have_adt
ffa191
   gdm_session_worker_src += 'gdm-session-solaris-auditor.c'
ffa191
 endif
ffa191
 
ffa191
 gdm_session_worker = executable('gdm-session-worker',
f83012
-- 
0cfcbe
2.33.1
f83012