@dbus.service.method("id.waydro.ContainerManager", in_signature='a{ss}', out_signature='', sender_keyword="sender", connection_keyword="conn")
def Start(self, session, sender, conn):
- if session["user_id"] != "0":
- dbus_info = dbus.Interface(conn.get_object("org.freedesktop.DBus", "/org/freedesktop/DBus/Bus", False), "org.freedesktop.DBus")
- uid = dbus_info.GetConnectionUnixUser(sender)
- if str(uid) != session["user_id"]:
- raise RuntimeError("Cannot start a session on behalf of another user")
+ dbus_info = dbus.Interface(conn.get_object("org.freedesktop.DBus", "/org/freedesktop/DBus/Bus", False), "org.freedesktop.DBus")
+ uid = dbus_info.GetConnectionUnixUser(sender)
+ if str(uid) not in ["0", session["user_id"]]:
+ raise RuntimeError("Cannot start a session on behalf of another user")
do_start(self.args, session)
@dbus.service.method("id.waydro.ContainerManager", in_signature='b', out_signature='')
helpers.protocol.set_aidl_version(args)
- # Mount data
- helpers.mount.bind(args, session["waydroid_data"],
- tools.config.defaults["data"])
-
# Cgroup hacks
if which("start"):
command = ["start", "cgroup-lite"]
# Set permissions
set_permissions(args)
+ # Create session-specific LXC config file
+ helpers.lxc.generate_session_lxc_config(args, session)
+ # Backwards compatibility
+ with open(tools.config.defaults["lxc"] + "/waydroid/config") as f:
+ if "config_session" not in f.read():
+ helpers.mount.bind(args, session["waydroid_data"],
+ tools.config.defaults["data"])
+
helpers.lxc.start(args)
services.hardware_manager.start(args)
# Umount rootfs
helpers.images.umount_rootfs(args)
- # Umount data
- helpers.mount.umount_all(args, tools.config.defaults["data"])
+ # Backwards compatibility
+ try:
+ helpers.mount.umount_all(args, tools.config.defaults["data"])
+ except:
+ pass
if "session" in args:
if quit_session: