X-Git-Url: https://www.chiark.greenend.org.uk/ucgi/~ianmdlvl/git?a=blobdiff_plain;f=src%2Flogind.h;h=be8bb1d389a37b033f95cee088835856a5ba0b62;hb=18fa6b2705aaef42041942f47f013e426640b6a4;hp=fdc780feb66cbcd9b3445b171b0ca79be564615e;hpb=91f9dcaf9270fe465525638cc08bd94590273349;p=elogind.git diff --git a/src/logind.h b/src/logind.h index fdc780feb..be8bb1d38 100644 --- a/src/logind.h +++ b/src/logind.h @@ -35,10 +35,10 @@ /* TODO: * * recreate VTs when disallocated - * PAM rewrite * spawn user systemd - * dbus API * direct client API + * D-Bus method: AttachDevices(seat, devices[]); + * D-Bus method: SetLinger(user, bool b); * * non-local X11 server * reboot/shutdown halt management @@ -76,11 +76,23 @@ struct Manager { Seat *vtconsole; char *cgroup_path; - char **controllers, **reset_controllers; + char **controllers; char **kill_only_users, **kill_exclude_users; bool kill_user_processes; + + unsigned long session_counter; + + Hashmap *cgroups; + Hashmap *pipe_fds; +}; + +enum { + FD_UDEV, + FD_CONSOLE, + FD_BUS, + FD_PIPE_BASE }; Manager *manager_new(void); @@ -106,10 +118,18 @@ int manager_startup(Manager *m); int manager_run(Manager *m); int manager_spawn_autovt(Manager *m, int vtnr); +void manager_cgroup_notify_empty(Manager *m, const char *cgroup); + void manager_gc(Manager *m); +int manager_get_idle_hint(Manager *m, dual_timestamp *t); + bool x11_display_is_local(const char *display); extern const DBusObjectPathVTable bus_manager_vtable; +DBusHandlerResult bus_message_filter(DBusConnection *c, DBusMessage *message, void *userdata); + +int manager_send_changed(Manager *manager, const char *properties); + #endif