xml escape notifications sent via libnotify (Closes: #1185)

This commit is contained in:
Damien Churchill 2010-04-27 10:24:16 +01:00
parent d6b7917350
commit 412b96ba55
2 changed files with 42 additions and 6 deletions

View File

@ -550,6 +550,40 @@ def path_join(*parts):
path += '/' + part
return path
XML_ESCAPES = (
('&', '&'),
('<', '&lt;'),
('>', '&gt;'),
('"', '&quot;'),
("'", '&apos;')
)
def xml_decode(string):
"""
Unescape a string that was previously encoded for use within xml.
:param string: The string to escape
:type string: string
:returns: The unescaped version of the string.
:rtype: string
"""
for char, escape in XML_ESCAPES:
string = string.replace(escape, char)
return string
def xml_encode(string):
"""
Escape a string for use within an xml element or attribute.
:param string: The string to escape
:type string: string
:returns: An escaped version of the string.
:rtype: string
"""
for char, escape in XML_ESCAPES:
string = string.replace(char, escape)
return string
class VersionSplit(object):
"""
Used for comparing version numbers.

View File

@ -74,9 +74,11 @@ class Notification:
except:
log.warning("pynotify is not installed")
else:
if pynotify.init("Deluge"):
self.note = pynotify.Notification(_("Torrent complete"),
status["name"] + "\n" + _("Including %i files" % status["num_files"]))
if not pynotify.init("Deluge"):
return
title = deluge.common.xml_encode(_("Torrent complete"))
message = deluge.common.xml_encode(status["name"] + "\n" + _("Including %i files" % status["num_files"]))
self.note = pynotify.Notification(title, message)
self.note.set_icon_from_pixbuf(common.get_logo(48))
if not self.note.show():
log.warning("pynotify failed to show notification")