На этот вопрос уже есть ответ здесь:
Я бы хотел, чтобы мои дети пользовались компьютером только в течение 30 минут, после чего я бы хотел, чтобы экран был заблокирован. Если в этот момент я решу снова разблокировать экран, я бы хотел, чтобы экран снова заблокировался еще через 30 минут.
Как я могу написать сценарий для этого?
Спасибо за справку. Я решил объединить части Вашего ответа с другим материалом, который я нашел онлайн и предложил это решение в Python 2.x:
import gobject, dbus, time, subprocess
from dbus.mainloop.glib import DBusGMainLoop
time.sleep(30*60)
subprocess.Popen(["gnome-screensaver-command", "-l"])
def lock_status(bus, message):
if message.get_member() != "EventEmitted":
return
args = message.get_args_list()
if args[0] == "desktop-unlock":
time.sleep(30*60)
subprocess.Popen(["gnome-screensaver-command", "-l"])
DBusGMainLoop(set_as_default=True)
bus = dbus.SessionBus()
bus.add_match_string("type='signal',interface='com.ubuntu.Upstart0_6'")
bus.add_message_filter(lock_status)
gobject.MainLoop().run()
Запустите скрипт ниже в фоновом режиме, и он заблокирует экран после произвольного числа минут:
#!/usr/bin/env python3
import subprocess
import time
import sys
t = 0; max_t = int(sys.argv[1])
while True:
# check runs once per minute
time.sleep(60)
# check the lock status, add 1 to current time if not locked, else t = 0
try:
subprocess.check_output(["pgrep", "-cf", "lockscreen-mode"]).decode("utf-8").strip()
t = 0
except subprocess.CalledProcessError:
t += 1
# if unlocked status time exceeds set time (in minutes), lock screen
if t >= max_t:
subprocess.Popen(["gnome-screensaver-command", "-l"])
t = 0
lock_screen.py
Тестовый прогон это от терминала с блокировкой - время как аргумент (минуты)
python3 /path/to/lock_screen.py 30
(Хотя для теста, я занял бы более короткое время),
Если все хорошо работает, добавьте его для Запущения Тире Приложений>, Приложения Запуска> Добавляют. Добавьте команду:
python3 /path/to/lock_screen.py 30
Представленный рев сценария запускается после пользовательского входа в систему и ожидает определенное количество времени прежде, чем заблокировать экран. Два протеста должны иметься в виду: сценарий должен быть частью Приложений Запуска, и это должен быть исполняемый файл.
Время для каждой сессии может быть настроено в рамках самого сценария путем изменения TIME
переменная, согласно /bin/sleep
использование. От man sleep
:
Пауза в течение секунд ЧИСЛА. СУФФИКС Может быть' в течение многих секунд (значение по умолчанию), 'm' в течение многих минут, 'h' в течение многих часов или 'd' в течение многих дней. В отличие от большинства реализаций, которые требуют, ЧИСЛО является целым числом, здесь ЧИСЛО может быть произвольным числом с плавающей точкой.
Сценарий может быть запущен вручную или как часть Приложений Запуска, которые назовут после каждого входа в систему GUI. Обратитесь к тому, Как я запускаю приложения автоматически на входе в систему? для этого.
Простая установка
bin
в Вашей персональной ДОМАШНЕЙ папке.bin
папка создает названный файл sessionLocker.sh
. Скопируйте исходный код в тот файлchmod +x $HOME/bin/sessionLocker.sh
в терминале/home/MYUSERNAME/bin/sessionLocker.sh
Сценарий также отправляется на моем персональном GitHub. Использовать git clone https://github.com/SergKolo/sergrep.git
загружать исходный код.
Источник сценария
#!/bin/bash
##################################################
# AUTHOR: Serg Kolo
# Date: Jan 2nd 2016
# Description: A script that locks session every x
# minutes.
# TESTED ON: 14.04.3 LTS, Trusty Tahr
# WRITTEN FOR: https://askubuntu.com/q/715721/295286
# Depends: qbus, dbus, Unity desktop
###################################################
# Copyright (c) 2016 Serg Kolo
#
# Permission is hereby granted, free of charge, to any person obtaining a copy
# of this software and associated documentation files (the "Software"), to deal in
# the Software without restriction, including without limitation the rights to use,
# copy, modify, merge, publish, distribute, sublicense, and/or sell copies of
# the Software, and to permit persons to whom the Software is furnished to do so,
# subject to the following conditions:
#
# The above copyright notice and this permission notice shall be included in all
# copies or substantial portions of the Software.
#
# THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR IMPLIED,
# INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, FITNESS FOR A
# PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT
# HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION
# OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE
# SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
##############
# INTRODUCTION
##############
# This script locks user session every x minutes, and repeats this task
# upon user re-logging in. Useful for creating session for children, study session
# for college students, pomodoro sessions for self-learners ,etc.
#
# This can be started manually or as part of Startup Applications
###########
# VARIABLES
###########
TIME="30m"
##########
# MAIN
##########
while [ 1 ];
do
# Wait the time defined in VARIABLES part and lock the session
/bin/sleep $TIME && qdbus com.canonical.Unity /com/canonical/Unity/Session com.canonical.Unity.Session.Lock
# Continuously query dbus every 0.25 seconds test whether session is locked
# Once this sub-loop breaks, the main one can resume the wait and lock cycle.
while [ $(qdbus com.canonical.Unity /com/canonical/Unity/Session com.canonical.Unity.Session.IsLocked) == "true" ];
do
/bin/sleep 0.25 && continue
done
done