XEP-0223: Add more types and docs, and switch to new kwargs

This commit is contained in:
mathieui 2021-02-13 18:50:20 +01:00
parent 6520376977
commit 3b43d8eb7f

View File

@ -5,6 +5,7 @@
# See the file LICENSE for copying permission. # See the file LICENSE for copying permission.
import logging import logging
from asyncio import Future
from typing import Optional, Callable, List from typing import Optional, Callable, List
from slixmpp import JID from slixmpp import JID
from slixmpp.xmlstream import register_stanza_plugin, ElementBase from slixmpp.xmlstream import register_stanza_plugin, ElementBase
@ -28,28 +29,24 @@ class XEP_0223(BasePlugin):
profile = {'pubsub#persist_items': True, profile = {'pubsub#persist_items': True,
'pubsub#access_model': 'whitelist'} 'pubsub#access_model': 'whitelist'}
def configure(self, node, ifrom=None, callback=None, timeout=None): def configure(self, node: str, **iqkwargs) -> Future:
""" """
Update a node's configuration to match the public storage profile. Update a node's configuration to match the private storage profile.
:param node: Node to set the configuration at.
""" """
# TODO: that cannot possibly work, why is this here?
config = self.xmpp['xep_0004'].Form() config = self.xmpp['xep_0004'].Form()
config['type'] = 'submit' config['type'] = 'submit'
for field, value in self.profile.items(): for field, value in self.profile.items():
config.add_field(var=field, value=value) config.add_field(var=field, value=value)
return self.xmpp['xep_0060'].set_node_config(None, node, config, return self.xmpp['xep_0060'].set_node_config(
ifrom=ifrom, jid=None, node=node, config=config, **iqkwargs
callback=callback, )
timeout=timeout)
def store(self, stanza: ElementBase, node: Optional[str] = None, def store(self, stanza: ElementBase, node: Optional[str] = None,
id: Optional[str] = None, ifrom: Optional[JID] = None, id: Optional[str] = None, **pubsubkwargs) -> Future:
options: Optional[Form] = None,
callback: Optional[Callable] = None,
timeout: Optional[int] = None,
timeout_callback: Optional[Callable] = None):
""" """
Store private data via PEP. Store private data via PEP.
@ -63,6 +60,7 @@ class XEP_0223(BasePlugin):
:param options: Publish options to use, which will be modified to :param options: Publish options to use, which will be modified to
fit the persistent storage option profile. fit the persistent storage option profile.
""" """
options = pubsubkwargs.pop('options', None)
if not options: if not options:
options = self.xmpp['xep_0004'].stanza.Form() options = self.xmpp['xep_0004'].stanza.Form()
options['type'] = 'submit' options['type'] = 'submit'
@ -77,17 +75,11 @@ class XEP_0223(BasePlugin):
options.add_field(var=field) options.add_field(var=field)
options.get_fields()[field]['value'] = value options.get_fields()[field]['value'] = value
return self.xmpp['xep_0163'].publish(stanza, node, options=options, pubsubkwargs['options'] = options
ifrom=ifrom, callback=callback, return self.xmpp['xep_0163'].publish(stanza, node, id=id, **pubsubkwargs)
timeout=timeout,
timeout_callback=timeout_callback)
def retrieve(self, node: str, id: Optional[str] = None, def retrieve(self, node: str, id: Optional[str] = None,
item_ids: Optional[List[str]] = None, item_ids: Optional[List[str]] = None, **iqkwargs) -> Future:
ifrom: Optional[JID] = None,
callback: Optional[Callable] = None,
timeout: Optional[int] = None,
timeout_callback: Optional[Callable] = None):
""" """
Retrieve private data via PEP. Retrieve private data via PEP.
@ -98,22 +90,17 @@ class XEP_0223(BasePlugin):
:param id: Optionally specify the ID of the item. :param id: Optionally specify the ID of the item.
:param item_ids: Specify a group of IDs. If id is also specified, it :param item_ids: Specify a group of IDs. If id is also specified, it
will be included in item_ids. will be included in item_ids.
:param ifrom: Specify the sender's JID.
:param timeout: The length of time (in seconds) to wait for a response
before exiting the send call if blocking is used.
Defaults to slixmpp.xmlstream.RESPONSE_TIMEOUT
:param callback: Optional reference to a stream handler function. Will
be executed when a reply stanza is received.
""" """
if item_ids is None: if item_ids is None:
item_ids = [] item_ids = []
if id is not None: if id is not None:
item_ids.append(id) item_ids.append(id)
return self.xmpp['xep_0060'].get_items(None, node, return self.xmpp['xep_0060'].get_items(
item_ids=item_ids, ifrom=ifrom, jid=None, node=node,
callback=callback, timeout=timeout, item_ids=item_ids,
timeout_callback=timeout_callback) **iqkwargs
)
register_plugin(XEP_0223) register_plugin(XEP_0223)