Skip to content
Projects
Groups
Snippets
Help
Loading...
Help
Submit feedback
Contribute to GitLab
Sign in
Toggle navigation
V
vmj-qt
Project
Project
Details
Activity
Releases
Cycle Analytics
Repository
Repository
Files
Commits
Branches
Tags
Contributors
Graph
Compare
Charts
Issues
0
Issues
0
List
Boards
Labels
Milestones
Merge Requests
0
Merge Requests
0
CI / CD
CI / CD
Pipelines
Jobs
Schedules
Charts
Wiki
Wiki
Snippets
Snippets
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Charts
Create a new issue
Jobs
Commits
Issue Boards
Open sidebar
Kulya
vmj-qt
Commits
94533e56
Commit
94533e56
authored
Aug 01, 2016
by
Dan Pascu
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
Always have an offline status document (even without an offline note)
parent
c0b6a8e0
Changes
1
Hide whitespace changes
Inline
Side-by-side
Showing
1 changed file
with
25 additions
and
5 deletions
+25
-5
presence.py
blink/presence.py
+25
-5
No files found.
blink/presence.py
View file @
94533e56
...
@@ -117,11 +117,11 @@ class BlinkPresenceState(object):
...
@@ -117,11 +117,11 @@ class BlinkPresenceState(object):
@
property
@
property
def
offline_state
(
self
):
def
offline_state
(
self
):
blink_settings
=
BlinkSettings
()
if
self
.
account
is
BonjourAccount
():
if
self
.
account
is
BonjourAccount
()
or
not
blink_settings
.
presence
.
offline_note
:
return
None
return
None
blink_settings
=
BlinkSettings
()
account_id
=
hashlib
.
md5
(
self
.
account
.
id
)
.
hexdigest
()
account_id
=
hashlib
.
md5
(
self
.
account
.
id
)
.
hexdigest
()
timestamp
=
ISOTimestamp
.
now
()
timestamp
=
ISOTimestamp
.
now
()
...
@@ -141,7 +141,8 @@ class BlinkPresenceState(object):
...
@@ -141,7 +141,8 @@ class BlinkPresenceState(object):
service
.
capabilities
=
caps
.
ServiceCapabilities
()
service
.
capabilities
=
caps
.
ServiceCapabilities
()
service
.
display_name
=
self
.
account
.
display_name
or
None
service
.
display_name
=
self
.
account
.
display_name
or
None
service
.
icon
=
"
%
s#blink-icon
%
s"
%
(
self
.
account
.
xcap
.
icon
.
url
,
self
.
account
.
xcap
.
icon
.
etag
)
if
self
.
account
.
xcap
.
icon
is
not
None
else
None
service
.
icon
=
"
%
s#blink-icon
%
s"
%
(
self
.
account
.
xcap
.
icon
.
url
,
self
.
account
.
xcap
.
icon
.
etag
)
if
self
.
account
.
xcap
.
icon
is
not
None
else
None
service
.
notes
.
add
(
blink_settings
.
presence
.
offline_note
)
if
blink_settings
.
presence
.
offline_note
:
service
.
notes
.
add
(
blink_settings
.
presence
.
offline_note
)
doc
.
add
(
service
)
doc
.
add
(
service
)
return
doc
return
doc
...
@@ -150,6 +151,9 @@ class BlinkPresenceState(object):
...
@@ -150,6 +151,9 @@ class BlinkPresenceState(object):
class
PresencePublicationHandler
(
object
):
class
PresencePublicationHandler
(
object
):
implements
(
IObserver
)
implements
(
IObserver
)
def
__init__
(
self
):
self
.
_should_set_offline_status
=
set
()
def
start
(
self
):
def
start
(
self
):
notification_center
=
NotificationCenter
()
notification_center
=
NotificationCenter
()
notification_center
.
add_observer
(
self
,
name
=
'SIPAccountWillActivate'
)
notification_center
.
add_observer
(
self
,
name
=
'SIPAccountWillActivate'
)
...
@@ -192,9 +196,11 @@ class PresencePublicationHandler(object):
...
@@ -192,9 +196,11 @@ class PresencePublicationHandler(object):
account
.
save
()
account
.
save
()
elif
{
'presence.enabled'
,
'display_name'
,
'xcap.icon'
}
.
intersection
(
notification
.
data
.
modified
)
and
account
.
presence
.
enabled
:
elif
{
'presence.enabled'
,
'display_name'
,
'xcap.icon'
}
.
intersection
(
notification
.
data
.
modified
)
and
account
.
presence
.
enabled
:
account
.
presence_state
=
BlinkPresenceState
(
account
)
.
online_state
account
.
presence_state
=
BlinkPresenceState
(
account
)
.
online_state
if
account
.
enabled
and
account
.
xcap_available
:
if
account
.
enabled
and
account
.
xcap_available
and
(
set
(
notification
.
data
.
modified
)
!=
{
'xcap.icon'
}
or
account
.
id
in
self
.
_should_set_offline_status
)
:
state
=
BlinkPresenceState
(
account
)
.
offline_state
state
=
BlinkPresenceState
(
account
)
.
offline_state
account
.
xcap_manager
.
set_offline_status
(
OfflineStatus
(
state
)
if
state
is
not
None
else
None
)
account
.
xcap_manager
.
set_offline_status
(
OfflineStatus
(
state
)
if
state
is
not
None
else
None
)
if
account
.
id
in
self
.
_should_set_offline_status
:
# do not use set.discard() here to avoid race conditions. it should only be removed if present.
self
.
_should_set_offline_status
.
remove
(
account
.
id
)
def
_NH_SIPAccountWillActivate
(
self
,
notification
):
def
_NH_SIPAccountWillActivate
(
self
,
notification
):
account
=
notification
.
sender
account
=
notification
.
sender
...
@@ -259,6 +265,13 @@ class PresencePublicationHandler(object):
...
@@ -259,6 +265,13 @@ class PresencePublicationHandler(object):
blink_settings
.
presence
.
offline_note
=
offline_note
blink_settings
.
presence
.
offline_note
=
offline_note
blink_settings
.
save
()
blink_settings
.
save
()
try
:
offline_icon
=
next
(
service
.
icon
for
service
in
offline_status
.
pidf
.
services
)
except
(
AttributeError
,
StopIteration
):
offline_icon_hash
=
None
else
:
offline_icon_hash
=
str
(
offline_icon
)
.
partition
(
'#blink-icon'
)[
2
]
or
None
if
status_icon
:
if
status_icon
:
icon_hash
=
hashlib
.
sha1
(
status_icon
.
data
)
.
hexdigest
()
icon_hash
=
hashlib
.
sha1
(
status_icon
.
data
)
.
hexdigest
()
icon_desc
=
IconDescriptor
(
status_icon
.
url
,
icon_hash
)
icon_desc
=
IconDescriptor
(
status_icon
.
url
,
icon_hash
)
...
@@ -266,7 +279,14 @@ class PresencePublicationHandler(object):
...
@@ -266,7 +279,14 @@ class PresencePublicationHandler(object):
icon
=
icon_manager
.
store_data
(
'avatar'
,
status_icon
.
data
)
icon
=
icon_manager
.
store_data
(
'avatar'
,
status_icon
.
data
)
blink_settings
.
presence
.
icon
=
IconDescriptor
(
FileURL
(
icon
.
filename
),
icon_hash
)
if
icon
is
not
None
else
None
blink_settings
.
presence
.
icon
=
IconDescriptor
(
FileURL
(
icon
.
filename
),
icon_hash
)
if
icon
is
not
None
else
None
blink_settings
.
save
()
blink_settings
.
save
()
elif
account
.
xcap
.
icon
!=
icon_desc
and
icon_hash
!=
offline_icon_hash
:
self
.
_should_set_offline_status
.
add
(
account
.
id
)
else
:
else
:
if
blink_settings
.
presence
.
icon
is
None
is
not
account
.
xcap
.
icon
:
self
.
_should_set_offline_status
.
add
(
account
.
id
)
elif
blink_settings
.
presence
.
icon
is
account
.
xcap
.
icon
is
offline_status
is
None
and
account
.
xcap_manager
.
pidf_manipulation
.
supported
:
state
=
BlinkPresenceState
(
account
)
.
offline_state
account
.
xcap_manager
.
set_offline_status
(
OfflineStatus
(
state
)
if
state
is
not
None
else
None
)
icon_desc
=
None
icon_desc
=
None
icon_manager
.
remove
(
'avatar'
)
icon_manager
.
remove
(
'avatar'
)
blink_settings
.
presence
.
icon
=
None
blink_settings
.
presence
.
icon
=
None
...
...
Write
Preview
Markdown
is supported
0%
Try again
or
attach a new file
Attach a file
Cancel
You are about to add
0
people
to the discussion. Proceed with caution.
Finish editing this message first!
Cancel
Please
register
or
sign in
to comment