Skip to content

Commit

Permalink
augment macos screensaver detection with screen lock detection
Browse files Browse the repository at this point in the history
Fixes #168
  • Loading branch information
ianwremmel authored and dschep committed May 31, 2018
1 parent 5e39201 commit ff9ad98
Showing 1 changed file with 14 additions and 2 deletions.
16 changes: 14 additions & 2 deletions ntfy/screensaver.py
Original file line number Diff line number Diff line change
Expand Up @@ -97,12 +97,24 @@ def macos_detect():


def macos_is_locked():
# Strictly-speaking, this detects whether or not the screensaver is running. The screensaver
# Strictly-speaking, this detects whether or not the screensaver is running. The screensaver
# may or may not be locked.
cmd = '''tell application "System Events"
get running of screen saver preferences
end tell'''
return check_output([ 'osascript', '-e', cmd ]) == b'true\n'
screensaver_is_running = check_output(
['osascript', '-e', cmd]) == b'true\n'
if screensaver_is_running:
return True

# The screen may be locked even if the scrensaver is not running. This
# *should* cover that scenario.
# https: // stackoverflow.com/questions/11505255/osx-check-if-the-screen-is-locked
import Quartz
d = Quartz.CGSessionCopyCurrentDictionary()
screen_is_locked = d.get("CGSSessionScreenIsLocked", 0) == 1

return screen_is_locked


def is_locked():
Expand Down

0 comments on commit ff9ad98

Please sign in to comment.