On 09/12/17 05:13, Michael Palimaka wrote: > On 09/12/2017 05:04 AM, Daniel Frey wrote: >> According to a comment in the bug, you can try to figure out which >> session it is (ck-list-sessions) and look for the X11 display property >> set. This will not work (or could be difficult) if you have several >> users using KDE at the same time and can't tell the sessions apart. >> >> Once you figure that out, remember the session name and: >> >> # su -c 'dbus-send --system --print-reply \ >> --dest="org.freedesktop.ConsoleKit" \ >> /org/freedesktop/ConsoleKit/<session name> \ >> org.freedesktop.ConsoleKit.Session.Unlock' >> > > If there a nice way to wrap this up in a script I'd be interesting in > shipping this for non-logind systems. > > Another option is sys-auth/elogind, which provides the logind interface > and tools (like loginctl) for non-systemd systems. This is what I've > been testing with OpenRC for some time. > > I read that ConsoleKit is also supporting the logind dbus interface now. > This would in theory make it easy to create a tool to unlock the > session, but I haven't had a chance to test it yet. >
Well, I forgot to disable my screen locker during an update and got bit by this again. It's a pain typing it manually (especially when you run a monitor in portrait mode.) I had some time and put together a general-purpose bash script. A note of warning, I'm not an expert at bash by any means, but I was able to test this several ways as I haven't restarted my computer yet. I'll attach it if someone else wants to try it out. It's simply called ck-unlock-session. Dan
#!/bin/sh # This script is to make unlocking using OpenRC/Consolekit easier when the KDE Screenlocker breaks. # # Version: 0.1 # Date written: February 2, 2018 # # Copyright (C) 2018 Daniel Frey # # This script is free software; you can redistribute it and/or # modify it under the terms of the GNU General Public License # as published by the Free Software Foundation; either version 2 # of the License, or (at your option) any later version. # # This script is distributed in the hope that it will be useful, # but WITHOUT ANY WARRANTY; without even the implied warranty of # MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the # GNU General Public License for more details. # # # Some notes: # -The switch processing/argument handling is very basic. # -This script assumes session names start with "Session" when listing # sessions. This is settable via a variable. # # Possible actions: # -h : Show help screen # -l : List current consolekit sessions # -u : Unlock specified session (one parameter required - the session name) # -a : Attempt to unlock all sessions # Return code documentation # # 0: Script executed normally # 1: Root access is not present for script # 2: No arguments passed # 3: Multiple actions requested, can only do one at a time # 4: Argument passed was not recognized # 5: Multiple arguments passed for unlock single session, only one needed # 6: The argument required for unlocksession() is missing (internal error) # Return code constants readonly ERR_NORMAL_OPERATION=0 readonly ERR_NO_ROOT=1 readonly ERR_NO_ARGS=2 readonly ERR_TOO_MANY_ACTIONS=3 readonly ERR_INVALID_ARGUMENTS=4 readonly ERR_TOO_MANY_ARGS=5 readonly ERR_INTERNAL_ARG_MISSING=6 # Action parameter constants readonly ACTION_NONE=0 readonly ACTION_HELP=1 readonly ACTION_LIST=2 readonly ACTION_UNLOCKALL=3 readonly ACTION_UNLOCK=4 # This is what's used to look for a session via consolekit. # By default, assume it is prefixed with "Session". SESSION_SEARCH_PREFIX=Session # Check to make sure script has root access, if not... abort now! if [ $EUID -ne 0 ]; then echo "This script must be run as root." exit $ERR_NO_ROOT fi function showhelp () { echo "`basename $0`: a script that helps unlock consolekit sessions Usage: `basename $0` [action] [parameters] Actions: -l : list current sessions available for unlocking -u : unlock session specified as a parameter -a : attempt to unlock all current sessions -h : this screen Parameters: The -u parameter requires a session name to unlock, use -l to list sessions. Example: To unlock a single session, use: `basename $0` -u Session1 No arguments will show this screen." } function listsessions() { # Get a list of all sessions, and remove the full colon from the session name ALLSESSIONS=`ck-list-sessions | grep -i ^$SESSION_SEARCH_PREFIX | rev | cut -c 2- | rev` echo echo "Sessions present on this machine, space-delineated:" echo echo $ALLSESSIONS echo echo echo "Session detail (to help locate a specific session:" ck-list-sessions | grep -A 2 -i ^$SESSION_SEARCH_PREFIX } function unlocksession () { # This function expects one parameter set (the session to unlock. # Make sure the parameter exists before continuing. if [[ -z ${1} ]]; then echo $ERR_INTERNAL_ARG_MISSING; fi echo "Attempting to unlock session $1; messages from dbus are not suppressed." # Finally, request the unlock. dbus-send --system --print-reply --dest="org.freedesktop.ConsoleKit" /org/freedesktop/ConsoleKit/$1 org.freedesktop.ConsoleKit.Session.Unlock } function unlockallsessions () { # Get a list of all sessions, and remove the full colon from the session name ALLSESSIONS=`ck-list-sessions | grep -i ^$SESSION_SEARCH_PREFIX | rev | cut -c 2- | rev` echo "Attempting to unlock all sessions. Messages from dbus are not suppressed." echo # Loop through results, attempt to unlock all sessions. # Count them and report at the end. COUNT=0 for i in $ALLSESSIONS; do dbus-send --system --print-reply --dest="org.freedesktop.ConsoleKit" /org/freedesktop/ConsoleKit/$i org.freedesktop.ConsoleKit.Session.Unlock let "COUNT+=1" done echo echo "Attempted to unlock $COUNT session(s)." } # Start of "main" routine # Initialize variables: # ACTION=default 0; used to make sure more than one action are not # specified at the same time. If an invalid argument was passed # (e.g. one without the hyphen prefix) it will be caught as well. ACTION=$ACTION_NONE # Show help if no arguments provided at all if [ $# -eq 0 ]; then showhelp; exit $ERR_NO_ARGS; fi # Process arguments passed, setting environment appropriately. # During this check, ensure only one action was requested. This # script will not do multiple things at a time. while getopts “hlau:” OPTION do case $OPTION in h) # Help action # Make sure multiple actions are not chosen. if [ $ACTION -ne $ACTION_NONE ]; then echo "You can only declare one action at a time!"; echo ""; showhelp; exit $ERR_TOO_MANY_ACTIONS; fi ACTION=$ACTION_HELP ;; l) # List action # Make sure multiple actions are not chosen. if [ $ACTION -ne $ACTION_NONE ]; then echo "You can only declare one action at a time!"; echo ""; showhelp; exit $ERR_TOO_MANY_ACTIONS; fi ACTION=$ACTION_LIST ;; a) # Enable all USB hubs/devices action # Make sure multiple actions are not chosen. if [ $ACTION -ne $ACTION_NONE ]; then echo "You can only declare one action at a time!"; echo ""; showhelp; exit $ERR_TOO_MANY_ACTIONS; fi ACTION=$ACTION_UNLOCKALL ;; u) # Enable specific hub/device via find command action # Make sure multiple actions are not chosen. if [ $ACTION -ne $ACTION_NONE ]; then echo "You can only declare one action at a time!"; echo ""; showhelp; exit $ERR_TOO_MANY_ACTIONS; fi ACTION=$ACTION_UNLOCK # Save session name passed for later UNLOCKSESSION=$OPTARG ;; ?) # Unknown parameter showhelp exit $ERR_INVALID_ARGUMENTS ;; esac done # If script reaches this point, only one action was specified, so it is safe # to continue processing. case $ACTION in $ACTION_HELP) # help action showhelp ;; $ACTION_LIST) # list action listsessions ;; $ACTION_UNLOCKALL) # unlock all sessions unlockallsessions ;; $ACTION_UNLOCK) # unlock single session unlocksession $UNLOCKSESSION ;; *) echo "Unrecognized action." echo showhelp exit $ERR_INVALID_ARGUMENTS ;; esac exit $ERR_NORMAL_OPERATION