2011-12-04 16:26:14 -08:00
|
|
|
# -*- coding: utf-8 -*-
|
2010-03-26 14:32:16 -07:00
|
|
|
"""
|
2011-12-04 16:26:14 -08:00
|
|
|
sleekxmpp.xmlstream.matcher.stanzapath
|
|
|
|
~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
|
2010-03-26 14:32:16 -07:00
|
|
|
|
2011-12-04 16:26:14 -08:00
|
|
|
Part of SleekXMPP: The Sleek XMPP Library
|
|
|
|
|
|
|
|
:copyright: (c) 2011 Nathanael C. Fritz
|
|
|
|
:license: MIT, see LICENSE for more details
|
2010-03-26 14:32:16 -07:00
|
|
|
"""
|
2010-01-15 21:07:28 -08:00
|
|
|
|
2010-09-01 11:28:43 -07:00
|
|
|
from sleekxmpp.xmlstream.matcher.base import MatcherBase
|
2012-01-17 22:28:44 -08:00
|
|
|
from sleekxmpp.xmlstream.stanzabase import fix_ns
|
2010-01-15 21:07:28 -08:00
|
|
|
|
2010-09-01 11:28:43 -07:00
|
|
|
|
|
|
|
class StanzaPath(MatcherBase):
|
|
|
|
|
|
|
|
"""
|
|
|
|
The StanzaPath matcher selects stanzas that match a given "stanza path",
|
|
|
|
which is similar to a normal XPath except that it uses the interfaces and
|
|
|
|
plugins of the stanza instead of the actual, underlying XML.
|
2012-01-17 22:28:44 -08:00
|
|
|
|
|
|
|
:param criteria: Object to compare some aspect of a stanza against.
|
2010-09-01 11:28:43 -07:00
|
|
|
"""
|
|
|
|
|
2012-01-17 22:28:44 -08:00
|
|
|
def __init__(self, criteria):
|
|
|
|
self._criteria = fix_ns(criteria, split=True,
|
|
|
|
propagate_ns=False,
|
|
|
|
default_ns='jabber:client')
|
|
|
|
self._raw_criteria = criteria
|
|
|
|
|
2010-09-01 11:28:43 -07:00
|
|
|
def match(self, stanza):
|
|
|
|
"""
|
|
|
|
Compare a stanza against a "stanza path". A stanza path is similar to
|
|
|
|
an XPath expression, but uses the stanza's interfaces and plugins
|
2011-12-04 16:26:14 -08:00
|
|
|
instead of the underlying XML. See the documentation for the stanza
|
|
|
|
:meth:`~sleekxmpp.xmlstream.stanzabase.ElementBase.match()` method
|
|
|
|
for more information.
|
2010-09-01 11:28:43 -07:00
|
|
|
|
2011-12-04 16:26:14 -08:00
|
|
|
:param stanza: The :class:`~sleekxmpp.xmlstream.stanzabase.ElementBase`
|
|
|
|
stanza to compare against.
|
2010-09-01 11:28:43 -07:00
|
|
|
"""
|
2012-01-17 22:28:44 -08:00
|
|
|
return stanza.match(self._criteria) or stanza.match(self._raw_criteria)
|