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

7b586f
From f12d17a6f4f76ba037e9126113684777a070a8f4 Mon Sep 17 00:00:00 2001
7b586f
From: Ray Strode <rstrode@redhat.com>
7b586f
Date: Mon, 20 Aug 2018 14:30:59 -0400
7b586f
Subject: [PATCH 3/4] daemon: save os-release in accountsservice
7b586f
7b586f
It can be useful to know what OS a user was running
7b586f
when they logged in (to detect upgrades).
7b586f
7b586f
This commit saves that information in accountsservice.
7b586f
---
7b586f
 daemon/Makefile.am                            | 10 ++
7b586f
 daemon/gdm-session-settings.c                 | 98 +++++++++++++++++++
7b586f
 data/Makefile.am                              |  2 +
7b586f
 .../com.redhat.AccountsServiceUser.System.xml | 10 ++
7b586f
 4 files changed, 120 insertions(+)
7b586f
 create mode 100644 data/com.redhat.AccountsServiceUser.System.xml
7b586f
7b586f
diff --git a/daemon/Makefile.am b/daemon/Makefile.am
7b586f
index 3b1b15122..b77c9276e 100644
7b586f
--- a/daemon/Makefile.am
7b586f
+++ b/daemon/Makefile.am
7b586f
@@ -14,137 +14,147 @@ AM_CPPFLAGS = \
7b586f
 	-DLIBEXECDIR=\"$(libexecdir)\"			\
7b586f
 	-DLOCALSTATEDIR=\"$(localstatedir)\"		\
7b586f
 	-DLOGDIR=\"$(logdir)\"				\
7b586f
 	-DSBINDIR=\"$(sbindir)\"			\
7b586f
 	-DSYSCONFDIR=\"$(sysconfdir)\"			\
7b586f
 	-DGNOMELOCALEDIR=\""$(datadir)/locale"\"	\
7b586f
 	-DGDM_RUN_DIR=\"$(GDM_RUN_DIR)\"		\
7b586f
 	-DGDM_XAUTH_DIR=\"$(GDM_XAUTH_DIR)\"		\
7b586f
 	-DGDM_SCREENSHOT_DIR=\"$(GDM_SCREENSHOT_DIR)\"		\
7b586f
 	-DGDM_CACHE_DIR=\""$(localstatedir)/cache/gdm"\"	\
7b586f
 	-DGDM_SESSION_DEFAULT_PATH=\"$(GDM_SESSION_DEFAULT_PATH)\" \
7b586f
 	$(DISABLE_DEPRECATED_CFLAGS)			\
7b586f
 	$(DAEMON_CFLAGS)				\
7b586f
 	$(XLIB_CFLAGS)					\
7b586f
 	$(WARN_CFLAGS)					\
7b586f
 	$(DEBUG_CFLAGS)					\
7b586f
 	$(SYSTEMD_CFLAGS)				\
7b586f
 	$(JOURNALD_CFLAGS)				\
7b586f
 	$(LIBSELINUX_CFLAGS)	 			\
7b586f
 	-DLANG_CONFIG_FILE=\"$(LANG_CONFIG_FILE)\"	\
7b586f
 	$(NULL)
7b586f
 
7b586f
 BUILT_SOURCES =					\
7b586f
 	gdm-display-glue.h			\
7b586f
 	gdm-manager-glue.h			\
7b586f
 	gdm-local-display-glue.h		\
7b586f
 	gdm-local-display-factory-glue.h	\
7b586f
 	gdm-session-glue.h			\
7b586f
 	gdm-session-worker-glue.h		\
7b586f
 	gdm-session-enum-types.h		\
7b586f
+	com.redhat.AccountsServiceUser.System.h \
7b586f
 	$(NULL)
7b586f
 
7b586f
 gdm-session-enum-types.h: gdm-session-enum-types.h.in gdm-session.h
7b586f
 	$(AM_V_GEN) glib-mkenums --template $^ > $@
7b586f
 
7b586f
 gdm-session-enum-types.c: gdm-session-enum-types.c.in gdm-session.h
7b586f
 	$(AM_V_GEN) glib-mkenums --template $^ > $@
7b586f
 
7b586f
 gdm-display-glue.c gdm-display-glue.h: gdm-display.xml Makefile.am
7b586f
 	$(AM_V_GEN)gdbus-codegen 					\
7b586f
 		--c-namespace=GdmDBus					\
7b586f
 		--interface-prefix=org.gnome.DisplayManager		\
7b586f
 		--generate-c-code=gdm-display-glue			\
7b586f
 		$(srcdir)/gdm-display.xml
7b586f
 
7b586f
 gdm-local-display-glue.c gdm-local-display-glue.h: gdm-local-display.xml Makefile.am
7b586f
 	$(AM_V_GEN)gdbus-codegen 					\
7b586f
 		--c-namespace=GdmDBus					\
7b586f
 		--interface-prefix=org.gnome.DisplayManager		\
7b586f
 		--generate-c-code=gdm-local-display-glue		\
7b586f
 		$(srcdir)/gdm-local-display.xml
7b586f
 
7b586f
 gdm-local-display-factory-glue.c gdm-local-display-factory-glue.h : gdm-local-display-factory.xml Makefile.am
7b586f
 	$(AM_V_GEN)gdbus-codegen 					\
7b586f
 		--c-namespace=GdmDBus					\
7b586f
 		--interface-prefix=org.gnome.DisplayManager		\
7b586f
 		--generate-c-code=gdm-local-display-factory-glue	\
7b586f
 		$(srcdir)/gdm-local-display-factory.xml
7b586f
 
7b586f
 gdm-manager-glue.c gdm-manager-glue.h : gdm-manager.xml Makefile.am
7b586f
 	$(AM_V_GEN)gdbus-codegen 					\
7b586f
 		--c-namespace=GdmDBus					\
7b586f
 		--interface-prefix=org.gnome.DisplayManager		\
7b586f
 		--generate-c-code=gdm-manager-glue			\
7b586f
 		$(srcdir)/gdm-manager.xml
7b586f
 
7b586f
 gdm-session-glue.c gdm-session-glue.h : gdm-session.xml Makefile.am
7b586f
 	$(AM_V_GEN)gdbus-codegen 					\
7b586f
 		--c-namespace=GdmDBus					\
7b586f
 		--interface-prefix=org.gnome.DisplayManager		\
7b586f
 		--generate-c-code=gdm-session-glue			\
7b586f
 		$(srcdir)/gdm-session.xml
7b586f
 
7b586f
 gdm-session-worker-glue.c gdm-session-worker-glue.h : gdm-session-worker.xml Makefile.am
7b586f
 	$(AM_V_GEN)gdbus-codegen 					\
7b586f
 		--c-namespace=GdmDBus					\
7b586f
 		--interface-prefix=org.gnome.DisplayManager		\
7b586f
 		--generate-c-code=gdm-session-worker-glue		\
7b586f
 		$(srcdir)/gdm-session-worker.xml
7b586f
 
7b586f
+com.redhat.AccountsServiceUser.System.c com.redhat.AccountsServiceUser.System.h: $(top_srcdir)/data/com.redhat.AccountsServiceUser.System.xml Makefile.am
7b586f
+	$(AM_V_GEN)gdbus-codegen 					\
7b586f
+		--c-namespace=Gdm					\
7b586f
+		--interface-prefix=com.redhat				\
7b586f
+		--generate-c-code=com.redhat.AccountsServiceUser.System	\
7b586f
+		$(top_srcdir)/data/com.redhat.AccountsServiceUser.System.xml
7b586f
+
7b586f
 noinst_PROGRAMS = 		\
7b586f
 	test-session-client	\
7b586f
 	$(NULL)
7b586f
 
7b586f
 test_session_client_SOURCES = \
7b586f
 	test-session-client.c	\
7b586f
 	$(NULL)
7b586f
 
7b586f
 nodist_test_session_client_SOURCES =	\
7b586f
 	gdm-session-glue.h		\
7b586f
 	gdm-session-glue.c		\
7b586f
 	gdm-manager-glue.h		\
7b586f
 	gdm-manager-glue.c		\
7b586f
 	$(NULL)
7b586f
 
7b586f
 test_session_client_LDADD =	\
7b586f
 	$(DAEMON_LIBS)		\
7b586f
 	$(NULL)
7b586f
 
7b586f
 libexec_PROGRAMS = 			\
7b586f
 	gdm-session-worker		\
7b586f
 	gdm-wayland-session		\
7b586f
 	gdm-x-session			\
7b586f
 	$(NULL)
7b586f
 
7b586f
 gdm_session_worker_SOURCES = 			\
7b586f
 	session-worker-main.c 			\
7b586f
+	com.redhat.AccountsServiceUser.System.h \
7b586f
+	com.redhat.AccountsServiceUser.System.c \
7b586f
 	gdm-session.c				\
7b586f
 	gdm-session.h				\
7b586f
 	gdm-session-settings.h			\
7b586f
 	gdm-session-settings.c			\
7b586f
 	gdm-session-auditor.h			\
7b586f
 	gdm-session-auditor.c			\
7b586f
 	gdm-session-record.c			\
7b586f
 	gdm-session-record.h			\
7b586f
 	gdm-session-worker.h			\
7b586f
 	gdm-session-worker.c			\
7b586f
 	gdm-session-worker-job.c		\
7b586f
 	gdm-session-worker-common.c		\
7b586f
 	gdm-session-worker-common.h		\
7b586f
 	gdm-dbus-util.c				\
7b586f
 	gdm-dbus-util.h				\
7b586f
 	$(NULL)
7b586f
 
7b586f
 if SUPPORTS_PAM_EXTENSIONS
7b586f
 gdm_session_worker_SOURCES += $(top_srcdir)/pam-extensions/gdm-pam-extensions.h
7b586f
 endif
7b586f
 
7b586f
 nodist_gdm_session_worker_SOURCES =		\
7b586f
 	gdm-session-glue.h			\
7b586f
 	gdm-session-glue.c			\
7b586f
 	gdm-session-worker-glue.c		\
7b586f
 	gdm-session-worker-glue.h		\
7b586f
 	gdm-session-enum-types.c		\
7b586f
 	gdm-session-enum-types.h		\
7b586f
 	$(NULL)
7b586f
 
7b586f
diff --git a/daemon/gdm-session-settings.c b/daemon/gdm-session-settings.c
7b586f
index 8463fad32..921e4d501 100644
7b586f
--- a/daemon/gdm-session-settings.c
7b586f
+++ b/daemon/gdm-session-settings.c
7b586f
@@ -1,70 +1,77 @@
7b586f
 /* gdm-session-settings.c - Loads session and language from ~/.dmrc
7b586f
  *
7b586f
  * Copyright (C) 2008 Red Hat, Inc.
7b586f
  *
7b586f
  * This program is free software; you can redistribute it and/or modify
7b586f
  * it under the terms of the GNU General Public License as published by
7b586f
  * the Free Software Foundation; either version 2, or (at your option)
7b586f
  * any later version.
7b586f
  *
7b586f
  * This program is distributed in the hope that it will be useful,
7b586f
  * but WITHOUT ANY WARRANTY; without even the implied warranty of
7b586f
  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
7b586f
  * GNU General Public License for more details.
7b586f
  *
7b586f
  * You should have received a copy of the GNU General Public License
7b586f
  * along with this program; if not, write to the Free Software
7b586f
  * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA
7b586f
  * 02110-1301, USA.
7b586f
  *
7b586f
  * Written by: Ray Strode <rstrode@redhat.com>
7b586f
  */
7b586f
 #include "config.h"
7b586f
 #include "gdm-session-settings.h"
7b586f
+#include "gdm-common.h"
7b586f
+
7b586f
+#include "com.redhat.AccountsServiceUser.System.h"
7b586f
 
7b586f
 #include <errno.h>
7b586f
 #include <pwd.h>
7b586f
 #include <string.h>
7b586f
 #include <sys/types.h>
7b586f
 #include <unistd.h>
7b586f
 
7b586f
 #include <glib.h>
7b586f
 #include <glib-object.h>
7b586f
 #include <glib/gi18n.h>
7b586f
 
7b586f
 #include <act/act-user-manager.h>
7b586f
 
7b586f
 struct _GdmSessionSettingsPrivate
7b586f
 {
7b586f
         ActUserManager *user_manager;
7b586f
         ActUser *user;
7b586f
+
7b586f
+        /* used for retrieving the last OS user logged in with */
7b586f
+        GdmAccountsServiceUserSystem *user_system_proxy;
7b586f
+
7b586f
         char *session_name;
7b586f
         char *session_type;
7b586f
         char *language_name;
7b586f
 };
7b586f
 
7b586f
 static void gdm_session_settings_finalize (GObject *object);
7b586f
 static void gdm_session_settings_class_install_properties (GdmSessionSettingsClass *
7b586f
                                               settings_class);
7b586f
 
7b586f
 static void gdm_session_settings_set_property (GObject      *object,
7b586f
                                               guint         prop_id,
7b586f
                                               const GValue *value,
7b586f
                                               GParamSpec   *pspec);
7b586f
 static void gdm_session_settings_get_property (GObject      *object,
7b586f
                                               guint         prop_id,
7b586f
                                               GValue       *value,
7b586f
                                               GParamSpec   *pspec);
7b586f
 
7b586f
 enum {
7b586f
         PROP_0 = 0,
7b586f
         PROP_SESSION_NAME,
7b586f
         PROP_SESSION_TYPE,
7b586f
         PROP_LANGUAGE_NAME,
7b586f
         PROP_IS_LOADED
7b586f
 };
7b586f
 
7b586f
 G_DEFINE_TYPE (GdmSessionSettings, gdm_session_settings, G_TYPE_OBJECT)
7b586f
 
7b586f
 static void
7b586f
 gdm_session_settings_class_init (GdmSessionSettingsClass *settings_class)
7b586f
@@ -107,60 +114,62 @@ gdm_session_settings_class_install_properties (GdmSessionSettingsClass *settings
7b586f
         g_object_class_install_property (object_class, PROP_LANGUAGE_NAME, param_spec);
7b586f
 
7b586f
         param_spec = g_param_spec_boolean ("is-loaded", NULL, NULL,
7b586f
                                            FALSE, G_PARAM_READABLE);
7b586f
         g_object_class_install_property (object_class, PROP_IS_LOADED, param_spec);
7b586f
 }
7b586f
 
7b586f
 static void
7b586f
 gdm_session_settings_init (GdmSessionSettings *settings)
7b586f
 {
7b586f
         settings->priv = G_TYPE_INSTANCE_GET_PRIVATE (settings,
7b586f
                                                      GDM_TYPE_SESSION_SETTINGS,
7b586f
                                                      GdmSessionSettingsPrivate);
7b586f
 
7b586f
         settings->priv->user_manager = act_user_manager_get_default ();
7b586f
 
7b586f
 }
7b586f
 
7b586f
 static void
7b586f
 gdm_session_settings_finalize (GObject *object)
7b586f
 {
7b586f
         GdmSessionSettings *settings;
7b586f
         GObjectClass *parent_class;
7b586f
 
7b586f
         settings = GDM_SESSION_SETTINGS (object);
7b586f
 
7b586f
         if (settings->priv->user != NULL) {
7b586f
                 g_object_unref (settings->priv->user);
7b586f
         }
7b586f
 
7b586f
+        g_clear_object (&settings->priv->user_system_proxy);
7b586f
+
7b586f
         g_free (settings->priv->session_name);
7b586f
         g_free (settings->priv->language_name);
7b586f
 
7b586f
         parent_class = G_OBJECT_CLASS (gdm_session_settings_parent_class);
7b586f
 
7b586f
         if (parent_class->finalize != NULL) {
7b586f
                 parent_class->finalize (object);
7b586f
         }
7b586f
 }
7b586f
 
7b586f
 void
7b586f
 gdm_session_settings_set_language_name (GdmSessionSettings *settings,
7b586f
                                         const char         *language_name)
7b586f
 {
7b586f
         g_return_if_fail (GDM_IS_SESSION_SETTINGS (settings));
7b586f
 
7b586f
         if (settings->priv->language_name == NULL ||
7b586f
             strcmp (settings->priv->language_name, language_name) != 0) {
7b586f
                 settings->priv->language_name = g_strdup (language_name);
7b586f
                 g_object_notify (G_OBJECT (settings), "language-name");
7b586f
         }
7b586f
 }
7b586f
 
7b586f
 void
7b586f
 gdm_session_settings_set_session_name (GdmSessionSettings *settings,
7b586f
                                        const char         *session_name)
7b586f
 {
7b586f
         g_return_if_fail (GDM_IS_SESSION_SETTINGS (settings));
7b586f
 
7b586f
         if (settings->priv->session_name == NULL ||
7b586f
@@ -261,69 +270,86 @@ gdm_session_settings_get_property (GObject    *object,
7b586f
 
7b586f
                 default:
7b586f
                         G_OBJECT_WARN_INVALID_PROPERTY_ID (object, prop_id, pspec);
7b586f
     }
7b586f
 }
7b586f
 
7b586f
 GdmSessionSettings *
7b586f
 gdm_session_settings_new (void)
7b586f
 {
7b586f
         GdmSessionSettings *settings;
7b586f
 
7b586f
         settings = g_object_new (GDM_TYPE_SESSION_SETTINGS,
7b586f
                                  NULL);
7b586f
 
7b586f
         return settings;
7b586f
 }
7b586f
 
7b586f
 gboolean
7b586f
 gdm_session_settings_is_loaded (GdmSessionSettings  *settings)
7b586f
 {
7b586f
         if (settings->priv->user == NULL) {
7b586f
                 return FALSE;
7b586f
         }
7b586f
 
7b586f
         return act_user_is_loaded (settings->priv->user);
7b586f
 }
7b586f
 
7b586f
 static void
7b586f
 load_settings_from_user (GdmSessionSettings *settings)
7b586f
 {
7b586f
+        const char *object_path;
7b586f
         const char *session_name;
7b586f
         const char *session_type;
7b586f
         const char *language_name;
7b586f
 
7b586f
         if (!act_user_is_loaded (settings->priv->user)) {
7b586f
                 g_warning ("GdmSessionSettings: trying to load user settings from unloaded user");
7b586f
                 return;
7b586f
         }
7b586f
 
7b586f
+        object_path = act_user_get_object_path (settings->priv->user);
7b586f
+
7b586f
+        if (object_path != NULL) {
7b586f
+                g_autoptr (GError) error = NULL;
7b586f
+                settings->priv->user_system_proxy = gdm_accounts_service_user_system_proxy_new_for_bus_sync (G_BUS_TYPE_SYSTEM,
7b586f
+                                                                                                             G_DBUS_PROXY_FLAGS_NONE,
7b586f
+                                                                                                             "org.freedesktop.Accounts",
7b586f
+                                                                                                             object_path,
7b586f
+                                                                                                             NULL,
7b586f
+                                                                                                             &error);
7b586f
+                if (error != NULL) {
7b586f
+                        g_debug ("GdmSessionSettings: couldn't retrieve user system proxy from accountsservice: %s",
7b586f
+                                 error->message);
7b586f
+                }
7b586f
+        }
7b586f
+
7b586f
         /* if the user doesn't have saved state, they don't have any settings worth reading */
7b586f
         if (!act_user_get_saved (settings->priv->user))
7b586f
                 goto out;
7b586f
 
7b586f
         session_type = act_user_get_session_type (settings->priv->user);
7b586f
         session_name = act_user_get_session (settings->priv->user);
7b586f
 
7b586f
         g_debug ("GdmSessionSettings: saved session is %s (type %s)", session_name, session_type);
7b586f
 
7b586f
         if (session_type != NULL && session_type[0] != '\0') {
7b586f
                 gdm_session_settings_set_session_type (settings, session_type);
7b586f
         }
7b586f
 
7b586f
         if (session_name != NULL && session_name[0] != '\0') {
7b586f
                 gdm_session_settings_set_session_name (settings, session_name);
7b586f
         }
7b586f
 
7b586f
         language_name = act_user_get_language (settings->priv->user);
7b586f
 
7b586f
         g_debug ("GdmSessionSettings: saved language is %s", language_name);
7b586f
         if (language_name != NULL && language_name[0] != '\0') {
7b586f
                 gdm_session_settings_set_language_name (settings, language_name);
7b586f
         }
7b586f
 
7b586f
 out:
7b586f
         g_object_notify (G_OBJECT (settings), "is-loaded");
7b586f
 }
7b586f
 
7b586f
 static void
7b586f
 on_user_is_loaded_changed (ActUser            *user,
7b586f
@@ -349,64 +375,136 @@ gdm_session_settings_load (GdmSessionSettings  *settings,
7b586f
         g_return_val_if_fail (!gdm_session_settings_is_loaded (settings), FALSE);
7b586f
 
7b586f
         if (settings->priv->user != NULL) {
7b586f
                 old_user = settings->priv->user;
7b586f
 
7b586f
                 g_signal_handlers_disconnect_by_func (G_OBJECT (settings->priv->user),
7b586f
                                                       G_CALLBACK (on_user_is_loaded_changed),
7b586f
                                                       settings);
7b586f
         } else {
7b586f
                 old_user = NULL;
7b586f
         }
7b586f
 
7b586f
         settings->priv->user = act_user_manager_get_user (settings->priv->user_manager,
7b586f
                                                           username);
7b586f
 
7b586f
         g_clear_object (&old_user);
7b586f
 
7b586f
         if (!act_user_is_loaded (settings->priv->user)) {
7b586f
                 g_signal_connect (settings->priv->user,
7b586f
                                   "notify::is-loaded",
7b586f
                                   G_CALLBACK (on_user_is_loaded_changed),
7b586f
                                   settings);
7b586f
                 return FALSE;
7b586f
         }
7b586f
 
7b586f
         load_settings_from_user (settings);
7b586f
 
7b586f
         return TRUE;
7b586f
 }
7b586f
 
7b586f
+static void
7b586f
+save_os_release (GdmSessionSettings *settings,
7b586f
+                 ActUser            *user)
7b586f
+{
7b586f
+        g_autoptr(GFile) file = NULL;
7b586f
+        g_autoptr(GError) error = NULL;
7b586f
+        g_autofree char *contents = NULL;
7b586f
+        g_auto(GStrv) lines = NULL;
7b586f
+        size_t i;
7b586f
+
7b586f
+        if (settings->priv->user_system_proxy == NULL) {
7b586f
+                g_debug ("GdmSessionSettings: not saving OS version to user account because accountsservice doesn't support it");
7b586f
+                return;
7b586f
+        }
7b586f
+
7b586f
+        file = g_file_new_for_path ("/etc/os-release");
7b586f
+
7b586f
+        if (!g_file_load_contents (file, NULL, &contents, NULL, NULL, &error)) {
7b586f
+                g_debug ("GdmSessionSettings: couldn't load /etc/os-release: %s", error->message);
7b586f
+                return;
7b586f
+        }
7b586f
+
7b586f
+        lines = g_strsplit (contents, "\n", -1);
7b586f
+        for (i = 0; lines[i] != NULL; i++) {
7b586f
+                char *p, *name, *name_end, *value, *value_end;
7b586f
+
7b586f
+                p = lines[i];
7b586f
+
7b586f
+                while (g_ascii_isspace (*p))
7b586f
+                        p++;
7b586f
+
7b586f
+                if (*p == '#' || *p == '\0')
7b586f
+                        continue;
7b586f
+                name = p;
7b586f
+                while (gdm_shell_var_is_valid_char (*p, p == name))
7b586f
+                        p++;
7b586f
+                name_end = p;
7b586f
+                while (g_ascii_isspace (*p))
7b586f
+                        p++;
7b586f
+                if (name == name_end || *p != '=') {
7b586f
+                        continue;
7b586f
+                }
7b586f
+                *name_end = '\0';
7b586f
+
7b586f
+                p++;
7b586f
+
7b586f
+                while (g_ascii_isspace (*p))
7b586f
+                        p++;
7b586f
+
7b586f
+                value = p;
7b586f
+                value_end = value + strlen(value) - 1;
7b586f
+
7b586f
+                if (value != value_end && *value == '"' && *value_end == '"') {
7b586f
+                        value++;
7b586f
+                        *value_end = '\0';
7b586f
+                }
7b586f
+
7b586f
+                if (strcmp (name, "ID") == 0) {
7b586f
+                        gdm_accounts_service_user_system_set_id (settings->priv->user_system_proxy,
7b586f
+                                                                 value);
7b586f
+                        g_debug ("GdmSessionSettings: setting system OS for user to '%s'", value);
7b586f
+                } else if (strcmp (name, "VERSION_ID") == 0) {
7b586f
+                        gdm_accounts_service_user_system_set_version_id (settings->priv->user_system_proxy,
7b586f
+                                                                         value);
7b586f
+                        g_debug ("GdmSessionSettings: setting system OS version for user to '%s'", value);
7b586f
+                }
7b586f
+        }
7b586f
+}
7b586f
+
7b586f
 gboolean
7b586f
 gdm_session_settings_save (GdmSessionSettings  *settings,
7b586f
                            const char          *username)
7b586f
 {
7b586f
         ActUser  *user;
7b586f
 
7b586f
         g_return_val_if_fail (GDM_IS_SESSION_SETTINGS (settings), FALSE);
7b586f
         g_return_val_if_fail (username != NULL, FALSE);
7b586f
         g_return_val_if_fail (gdm_session_settings_is_loaded (settings), FALSE);
7b586f
 
7b586f
         user = act_user_manager_get_user (settings->priv->user_manager,
7b586f
                                           username);
7b586f
 
7b586f
 
7b586f
         if (!act_user_is_loaded (user)) {
7b586f
                 g_object_unref (user);
7b586f
                 return FALSE;
7b586f
         }
7b586f
 
7b586f
         if (settings->priv->session_name != NULL) {
7b586f
                 act_user_set_session (user, settings->priv->session_name);
7b586f
         }
7b586f
 
7b586f
         if (settings->priv->session_type != NULL) {
7b586f
                 act_user_set_session_type (user, settings->priv->session_type);
7b586f
         }
7b586f
 
7b586f
         if (settings->priv->language_name != NULL) {
7b586f
                 act_user_set_language (user, settings->priv->language_name);
7b586f
         }
7b586f
+
7b586f
+        save_os_release (settings, user);
7b586f
+
7b586f
         g_object_unref (user);
7b586f
 
7b586f
         return TRUE;
7b586f
 }
7b586f
diff --git a/data/Makefile.am b/data/Makefile.am
7b586f
index 192dfa052..d69021985 100644
7b586f
--- a/data/Makefile.am
7b586f
+++ b/data/Makefile.am
7b586f
@@ -8,60 +8,62 @@ SUBDIRS =			\
7b586f
 	$(NULL)
7b586f
 
7b586f
 initdir = $(gdmconfdir)/Init
7b586f
 postdir = $(gdmconfdir)/PostSession
7b586f
 predir = $(gdmconfdir)/PreSession
7b586f
 postlogindir = $(gdmconfdir)/PostLogin
7b586f
 workingdir = $(GDM_WORKING_DIR)
7b586f
 xauthdir = $(GDM_XAUTH_DIR)
7b586f
 screenshotdir = $(GDM_SCREENSHOT_DIR)
7b586f
 cachedir = $(localstatedir)/cache/gdm
7b586f
 
7b586f
 Init: $(srcdir)/Init.in
7b586f
 	sed	-e 's,[@]X_PATH[@],$(X_PATH),g' \
7b586f
 		<$(srcdir)/Init.in >Init
7b586f
 
7b586f
 PreSession: $(srcdir)/PreSession.in
7b586f
 	sed	-e 's,[@]X_PATH[@],$(X_PATH),g' \
7b586f
 		<$(srcdir)/PreSession.in >PreSession
7b586f
 PostSession: $(srcdir)/PostSession.in
7b586f
 	sed	-e 's,[@]X_PATH[@],$(X_PATH),g' \
7b586f
 		<$(srcdir)/PostSession.in >PostSession
7b586f
 
7b586f
 gdm.conf-custom: $(srcdir)/gdm.conf-custom.in
7b586f
 	sed	-e 's,[@]GDM_DEFAULTS_CONF[@],$(GDM_DEFAULTS_CONF),g' \
7b586f
 		<$(srcdir)/gdm.conf-custom.in >gdm.conf-custom
7b586f
 
7b586f
 dbusconfdir = $(DBUS_SYS_DIR)
7b586f
 dbusconf_in_files = gdm.conf.in
7b586f
 dbusconf_DATA = $(dbusconf_in_files:.conf.in=.conf)
7b586f
 
7b586f
+EXTRA_DIST += com.redhat.AccountsServiceUser.System.xml
7b586f
+
7b586f
 @INTLTOOL_SCHEMAS_RULE@
7b586f
 @INTLTOOL_XML_NOMERGE_RULE@
7b586f
 
7b586f
 # dconf database and profile
7b586f
 dconf_db_files = \
7b586f
 	dconf/defaults/00-upstream-settings		\
7b586f
 	dconf/defaults/locks/00-upstream-settings-locks
7b586f
 
7b586f
 dconfdbdir = $(pkgdatadir)
7b586f
 dconfdb_DATA = greeter-dconf-defaults
7b586f
 greeter-dconf-defaults: $(dconf_db_files)
7b586f
 	$(AM_V_GEN) dconf compile $@ $(srcdir)/dconf/defaults
7b586f
 
7b586f
 dconfprofiledir = $(DATADIR)/dconf/profile
7b586f
 dconfprofile_DATA = dconf/gdm
7b586f
 
7b586f
 gsettings_SCHEMAS = org.gnome.login-screen.gschema.xml
7b586f
 @GSETTINGS_RULES@
7b586f
 
7b586f
 schemasdir = $(pkgdatadir)
7b586f
 schemas_in_files = gdm.schemas.in
7b586f
 schemas_DATA = $(schemas_in_files:.schemas.in=.schemas)
7b586f
 
7b586f
 gdm.schemas.in: $(srcdir)/gdm.schemas.in.in
7b586f
 	sed	-e 's,[@]GDMPREFETCHCMD[@],$(GDMPREFETCHCMD),g' \
7b586f
 		-e 's,[@]GDM_CUSTOM_CONF[@],$(GDM_CUSTOM_CONF),g' \
7b586f
 		-e 's,[@]GDM_USER_PATH[@],$(GDM_USER_PATH),g' \
7b586f
 		-e 's,[@]GDM_USERNAME[@],$(GDM_USERNAME),g' \
7b586f
 		-e 's,[@]GDM_GROUPNAME[@],$(GDM_GROUPNAME),g' \
7b586f
 		-e 's,[@]HALT_COMMAND[@],$(HALT_COMMAND),g' \
7b586f
diff --git a/data/com.redhat.AccountsServiceUser.System.xml b/data/com.redhat.AccountsServiceUser.System.xml
7b586f
new file mode 100644
7b586f
index 000000000..67f5f302c
7b586f
--- /dev/null
7b586f
+++ b/data/com.redhat.AccountsServiceUser.System.xml
7b586f
@@ -0,0 +1,10 @@
7b586f
+<node>
7b586f
+  <interface name="com.redhat.AccountsServiceUser.System">
7b586f
+
7b586f
+    <annotation name="org.freedesktop.Accounts.VendorExtension" value="true"/>
7b586f
+
7b586f
+    <property name="id" type="s" access="readwrite"/>
7b586f
+    <property name="version-id" type="s" access="readwrite"/>
7b586f
+
7b586f
+  </interface>
7b586f
+</node>
7b586f
-- 
7b586f
2.17.1
7b586f