1
/* -*- Mode: C; tab-width: 8; indent-tabs-mode: nil; c-basic-offset: 8 -*-
3
* Copyright (C) 2007 William Jon McCann <mccann@jhu.edu>
5
* This program is free software; you can redistribute it and/or modify
6
* it under the terms of the GNU General Public License as published by
7
* the Free Software Foundation; either version 2 of the License, or
8
* (at your option) any later version.
10
* This program is distributed in the hope that it will be useful,
11
* but WITHOUT ANY WARRANTY; without even the implied warranty of
12
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
13
* GNU General Public License for more details.
15
* You should have received a copy of the GNU General Public License
16
* along with this program; if not, write to the Free Software
17
* Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA.
32
#include <sys/types.h>
33
#include <sys/socket.h>
36
#include <glib/gi18n.h>
37
#include <glib-object.h>
39
#include "gdm-common.h"
40
#include "gdm-display.h"
41
#include "gdm-static-display.h"
42
#include "gdm-static-display-glue.h"
44
#define GDM_STATIC_DISPLAY_GET_PRIVATE(o) (G_TYPE_INSTANCE_GET_PRIVATE ((o), GDM_TYPE_STATIC_DISPLAY, GdmStaticDisplayPrivate))
46
struct GdmStaticDisplayPrivate
48
GdmDBusStaticDisplay *skeleton;
52
static void gdm_static_display_class_init (GdmStaticDisplayClass *klass);
53
static void gdm_static_display_init (GdmStaticDisplay *static_display);
55
G_DEFINE_TYPE (GdmStaticDisplay, gdm_static_display, GDM_TYPE_DISPLAY)
58
gdm_static_display_create_authority (GdmDisplay *display)
60
g_return_val_if_fail (GDM_IS_DISPLAY (display), FALSE);
62
GDM_DISPLAY_CLASS (gdm_static_display_parent_class)->create_authority (display);
68
gdm_static_display_add_user_authorization (GdmDisplay *display,
73
return GDM_DISPLAY_CLASS (gdm_static_display_parent_class)->add_user_authorization (display, username, filename, error);
77
gdm_static_display_remove_user_authorization (GdmDisplay *display,
81
return GDM_DISPLAY_CLASS (gdm_static_display_parent_class)->remove_user_authorization (display, username, error);
85
gdm_static_display_manage (GdmDisplay *display)
87
g_return_val_if_fail (GDM_IS_DISPLAY (display), FALSE);
89
GDM_DISPLAY_CLASS (gdm_static_display_parent_class)->manage (display);
95
gdm_static_display_finish (GdmDisplay *display)
99
g_return_val_if_fail (GDM_IS_DISPLAY (display), FALSE);
101
/* Don't call parent's finish since we don't ever
102
want to be put in the FINISHED state */
104
/* restart static displays */
105
gdm_display_unmanage (display);
107
status = gdm_display_get_status (display);
108
if (status != GDM_DISPLAY_FAILED) {
109
gdm_display_manage (display);
116
gdm_static_display_unmanage (GdmDisplay *display)
118
g_return_val_if_fail (GDM_IS_DISPLAY (display), FALSE);
120
GDM_STATIC_DISPLAY (display)->priv->first_login = FALSE;
122
GDM_DISPLAY_CLASS (gdm_static_display_parent_class)->unmanage (display);
128
gdm_static_display_get_timed_login_details (GdmDisplay *display,
133
GDM_DISPLAY_CLASS (gdm_static_display_parent_class)->get_timed_login_details (display, enabledp, usernamep, delayp);
135
if (!GDM_STATIC_DISPLAY (display)->priv->first_login) {
136
/* if this is autologin but not timed login, then disable
137
* autologin after the first one */
138
if (*enabledp && *delayp == 0) {
145
gdm_static_display_constructor (GType type,
146
guint n_construct_properties,
147
GObjectConstructParam *construct_properties)
149
GdmStaticDisplay *display;
151
display = GDM_STATIC_DISPLAY (G_OBJECT_CLASS (gdm_static_display_parent_class)->constructor (type,
152
n_construct_properties,
153
construct_properties));
155
display->priv->skeleton = GDM_DBUS_STATIC_DISPLAY (gdm_dbus_static_display_skeleton_new ());
157
g_dbus_object_skeleton_add_interface (gdm_display_get_object_skeleton (GDM_DISPLAY (display)),
158
G_DBUS_INTERFACE_SKELETON (display->priv->skeleton));
160
return G_OBJECT (display);
164
gdm_static_display_finalize (GObject *object)
166
GdmStaticDisplay *display = GDM_STATIC_DISPLAY (object);
168
g_clear_object (&display->priv->skeleton);
170
G_OBJECT_CLASS (gdm_static_display_parent_class)->finalize (object);
174
gdm_static_display_class_init (GdmStaticDisplayClass *klass)
176
GObjectClass *object_class = G_OBJECT_CLASS (klass);
177
GdmDisplayClass *display_class = GDM_DISPLAY_CLASS (klass);
179
object_class->constructor = gdm_static_display_constructor;
180
object_class->finalize = gdm_static_display_finalize;
182
display_class->create_authority = gdm_static_display_create_authority;
183
display_class->add_user_authorization = gdm_static_display_add_user_authorization;
184
display_class->remove_user_authorization = gdm_static_display_remove_user_authorization;
185
display_class->manage = gdm_static_display_manage;
186
display_class->finish = gdm_static_display_finish;
187
display_class->unmanage = gdm_static_display_unmanage;
188
display_class->get_timed_login_details = gdm_static_display_get_timed_login_details;
190
g_type_class_add_private (klass, sizeof (GdmStaticDisplayPrivate));
194
gdm_static_display_init (GdmStaticDisplay *static_display)
197
static_display->priv = GDM_STATIC_DISPLAY_GET_PRIVATE (static_display);
199
static_display->priv->first_login = TRUE;
203
gdm_static_display_new (int display_number)
208
x11_display = g_strdup_printf (":%d", display_number);
209
object = g_object_new (GDM_TYPE_STATIC_DISPLAY,
210
"x11-display-number", display_number,
211
"x11-display-name", x11_display,
213
g_free (x11_display);
215
return GDM_DISPLAY (object);