chiark / gitweb /
__thread --> thread_local for C11 compat
[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
111         sd_bus_message *create_message;
112
113         char *controller;
114         Hashmap *devices;
115
116         LIST_FIELDS(Session, sessions_by_user);
117         LIST_FIELDS(Session, sessions_by_seat);
118
119         LIST_FIELDS(Session, gc_queue);
120 };
121
122 Session *session_new(Manager *m, const char *id);
123 void session_free(Session *s);
124 void session_set_user(Session *s, User *u);
125 bool session_check_gc(Session *s, bool drop_not_started);
126 void session_add_to_gc_queue(Session *s);
127 int session_activate(Session *s);
128 bool session_is_active(Session *s);
129 int session_get_idle_hint(Session *s, dual_timestamp *t);
130 void session_set_idle_hint(Session *s, bool b);
131 int session_create_fifo(Session *s);
132 void session_remove_fifo(Session *s);
133 int session_start(Session *s);
134 int session_stop(Session *s);
135 int session_finalize(Session *s);
136 int session_save(Session *s);
137 int session_load(Session *s);
138 int session_kill(Session *s, KillWho who, int signo);
139
140 SessionState session_get_state(Session *u);
141
142 extern const sd_bus_vtable session_vtable[];
143 int session_node_enumerator(sd_bus *bus, const char *path,void *userdata, char ***nodes, sd_bus_error *error);
144 int session_object_find(sd_bus *bus, const char *path, const char *interface, void *userdata, void **found, sd_bus_error *error);
145 char *session_bus_path(Session *s);
146
147 int session_send_signal(Session *s, bool new_session);
148 int session_send_changed(Session *s, const char *properties, ...) _sentinel_;
149 int session_send_lock(Session *s, bool lock);
150 int session_send_lock_all(Manager *m, bool lock);
151
152 int session_send_create_reply(Session *s, sd_bus_error *error);
153
154 const char* session_state_to_string(SessionState t) _const_;
155 SessionState session_state_from_string(const char *s) _pure_;
156
157 const char* session_type_to_string(SessionType t) _const_;
158 SessionType session_type_from_string(const char *s) _pure_;
159
160 const char* session_class_to_string(SessionClass t) _const_;
161 SessionClass session_class_from_string(const char *s) _pure_;
162
163 const char *kill_who_to_string(KillWho k) _const_;
164 KillWho kill_who_from_string(const char *s) _pure_;
165
166 void session_mute_vt(Session *s);
167 void session_restore_vt(Session *s);
168
169 bool session_is_controller(Session *s, const char *sender);
170 int session_set_controller(Session *s, const char *sender, bool force);
171 void session_drop_controller(Session *s);