chiark / gitweb /
939476af557d8ac7c732067458164d11f4fcad30
[elogind.git] / src / login / logind-session.h
1 /*-*- Mode: C; c-basic-offset: 8; indent-tabs-mode: nil -*-*/
2
3 #pragma once
4
5 /***
6   This file is part of systemd.
7
8   Copyright 2011 Lennart Poettering
9
10   systemd is free software; you can redistribute it and/or modify it
11   under the terms of the GNU Lesser General Public License as published by
12   the Free Software Foundation; either version 2.1 of the License, or
13   (at your option) any later version.
14
15   systemd is distributed in the hope that it will be useful, but
16   WITHOUT ANY WARRANTY; without even the implied warranty of
17   MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
18   Lesser General Public License for more details.
19
20   You should have received a copy of the GNU Lesser General Public License
21   along with systemd; If not, see <http://www.gnu.org/licenses/>.
22 ***/
23
24 typedef struct Session Session;
25 typedef enum KillWho KillWho;
26
27 #include "list.h"
28 #include "util.h"
29 #include "logind.h"
30 #include "logind-seat.h"
31 #include "logind-session-device.h"
32 #include "logind-user.h"
33 #include "login-shared.h"
34
35 typedef enum SessionState {
36         SESSION_OPENING,  /* Session scope is being created */
37         SESSION_ONLINE,   /* Logged in */
38         SESSION_ACTIVE,   /* Logged in and in the fg */
39         SESSION_CLOSING,  /* Logged out, but scope is still there */
40         _SESSION_STATE_MAX,
41         _SESSION_STATE_INVALID = -1
42 } SessionState;
43
44 typedef enum SessionClass {
45         SESSION_USER,
46         SESSION_GREETER,
47         SESSION_LOCK_SCREEN,
48         SESSION_BACKGROUND,
49         _SESSION_CLASS_MAX,
50         _SESSION_CLASS_INVALID = -1
51 } SessionClass;
52
53 typedef enum SessionType {
54         SESSION_UNSPECIFIED,
55         SESSION_TTY,
56         SESSION_X11,
57         _SESSION_TYPE_MAX,
58         _SESSION_TYPE_INVALID = -1
59 } SessionType;
60
61 enum KillWho {
62         KILL_LEADER,
63         KILL_ALL,
64         _KILL_WHO_MAX,
65         _KILL_WHO_INVALID = -1
66 };
67
68 struct Session {
69         Manager *manager;
70
71         char *id;
72         SessionType type;
73         SessionClass class;
74
75         char *state_file;
76
77         User *user;
78
79         dual_timestamp timestamp;
80
81         char *tty;
82         char *display;
83
84         bool remote;
85         char *remote_user;
86         char *remote_host;
87         char *service;
88
89         char *scope;
90         char *scope_job;
91
92         Seat *seat;
93         unsigned int vtnr;
94         int vtfd;
95         sd_event_source *vt_source;
96
97         pid_t leader;
98         uint32_t audit_id;
99
100         int fifo_fd;
101         char *fifo_path;
102
103         sd_event_source *fifo_event_source;
104
105         bool idle_hint;
106         dual_timestamp idle_hint_timestamp;
107
108         bool in_gc_queue:1;
109         bool started:1;
110         bool closing:1;
111
112         sd_bus_message *create_message;
113
114         char *controller;
115         Hashmap *devices;
116
117         LIST_FIELDS(Session, sessions_by_user);
118         LIST_FIELDS(Session, sessions_by_seat);
119
120         LIST_FIELDS(Session, gc_queue);
121 };
122
123 Session *session_new(Manager *m, const char *id);
124 void session_free(Session *s);
125 void session_set_user(Session *s, User *u);
126 bool session_check_gc(Session *s, bool drop_not_started);
127 void session_add_to_gc_queue(Session *s);
128 int session_activate(Session *s);
129 bool session_is_active(Session *s);
130 int session_get_idle_hint(Session *s, dual_timestamp *t);
131 void session_set_idle_hint(Session *s, bool b);
132 int session_create_fifo(Session *s);
133 void session_remove_fifo(Session *s);
134 int session_start(Session *s);
135 int session_stop(Session *s);
136 int session_finalize(Session *s);
137 int session_save(Session *s);
138 int session_load(Session *s);
139 int session_kill(Session *s, KillWho who, int signo);
140
141 SessionState session_get_state(Session *u);
142
143 extern const sd_bus_vtable session_vtable[];
144 int session_node_enumerator(sd_bus *bus, const char *path,void *userdata, char ***nodes, sd_bus_error *error);
145 int session_object_find(sd_bus *bus, const char *path, const char *interface, void *userdata, void **found, sd_bus_error *error);
146 char *session_bus_path(Session *s);
147
148 int session_send_signal(Session *s, bool new_session);
149 int session_send_changed(Session *s, const char *properties, ...) _sentinel_;
150 int session_send_lock(Session *s, bool lock);
151 int session_send_lock_all(Manager *m, bool lock);
152
153 int session_send_create_reply(Session *s, sd_bus_error *error);
154
155 const char* session_state_to_string(SessionState t) _const_;
156 SessionState session_state_from_string(const char *s) _pure_;
157
158 const char* session_type_to_string(SessionType t) _const_;
159 SessionType session_type_from_string(const char *s) _pure_;
160
161 const char* session_class_to_string(SessionClass t) _const_;
162 SessionClass session_class_from_string(const char *s) _pure_;
163
164 const char *kill_who_to_string(KillWho k) _const_;
165 KillWho kill_who_from_string(const char *s) _pure_;
166
167 void session_mute_vt(Session *s);
168 void session_restore_vt(Session *s);
169
170 bool session_is_controller(Session *s, const char *sender);
171 int session_set_controller(Session *s, const char *sender, bool force);
172 void session_drop_controller(Session *s);