slidge.plugins.mattermost.contact
#
Module Contents#
Classes#
This class centralizes actions in relation to a specific legacy contact. |
|
A file attachment to a message |
|
Virtual roster of a gateway user, that allows to represent all |
Functions#
Attributes#
- class slidge.plugins.mattermost.contact.Contact(*a, **kw)[source]#
Bases:
slidge.LegacyContact
[str
]This class centralizes actions in relation to a specific legacy contact.
You shouldn’t create instances of contacts manually, but rather rely on
LegacyRoster.by_legacy_id()
to ensure that contact instances are singletons. TheLegacyRoster
instance of a session is accessible through theBaseSession.contacts
attribute.Typically, your plugin should have methods hook to the legacy events and call appropriate methods here to transmit the “legacy action” to the xmpp user. This should look like this:
Use
carbon=True
as a keyword arg for methods to represent an action FROM the user TO the contact, typically when the user uses an official client to do an action such as sending a message or marking as message as read. This will use XEP-0363 to impersonate the XMPP user in order.- Parameters:
session – The session this contact is part of
legacy_id – The contact’s legacy ID
jid_username – User part of this contact’s ‘puppet’ JID. NB: case-insensitive, and some special characters are not allowed
- async update_status(status=None, custom_status=None)[source]#
- Parameters:
status (Optional[str]) –
custom_status (Optional[mattermost_api_reference_client.models.UpdateUserCustomStatusJsonBody]) –
- async update_info(user=None)[source]#
Fetch information about this contact from the legacy network
This is awaited on Contact instantiation, and should be overridden to update the nickname, avatar, vcard [..] of this contact, by making “legacy API calls”.
- Parameters:
user (Optional[mattermost_api_reference_client.models.User]) –
- slidge.plugins.mattermost.contact.unset_to_none(x)[source]#
- Parameters:
x (Union[T, mattermost_api_reference_client.types.Unset]) –
- Return type:
Union[T, None]
- class slidge.plugins.mattermost.contact.Attachment[source]#
Bases:
slidge.util.types.LegacyAttachment
A file attachment to a message
At the minimum, one of the
path
,steam
,data
orurl
attribute has to be setTo be used with
LegacyContact.send_files()
orLegacyParticipant.send_files()
- class slidge.plugins.mattermost.contact.Roster(*a, **kw)[source]#
Bases:
slidge.LegacyRoster
[str
,Contact
]Virtual roster of a gateway user, that allows to represent all of their contacts as singleton instances (if used properly and not too bugged).
Every
BaseSession
instance will have its ownLegacyRoster
instance accessible via theBaseSession.contacts
attribute.Typically, you will mostly use the
LegacyRoster.by_legacy_id()
function to retrieve a contact instance.You might need to override
LegacyRoster.legacy_id_to_jid_username()
and/orLegacyRoster.jid_username_to_legacy_id()
to incorporate some custom logic if you need some characters when translation JID user parts and legacy IDs.- async by_jid(jid)[source]#
Retrieve a contact by their JID
If the contact was not instantiated before, it will be created using
slidge.LegacyRoster.jid_username_to_legacy_id()
to infer their legacy user ID.- Parameters:
contact_jid –
- Returns:
- async by_legacy_id(legacy_id, *_a, **_kw)[source]#
Retrieve a contact by their legacy_id
If the contact was not instantiated before, it will be created using
slidge.LegacyRoster.legacy_id_to_jid_username()
to infer their legacy user ID.- Parameters:
legacy_id (str) –
args – arbitrary additional positional arguments passed to the contact constructor. Requires subclassing LegacyContact.__init__ to accept those. This is useful for networks where you fetch the contact list and information about these contacts in a single request
kwargs – arbitrary keyword arguments passed to the contact constructor
- Returns:
- async fill()[source]#
Populate slidge’s “virtual roster”.
Override this and in it,
await self.by_legacy_id(contact_id)
for the every legacy contacts of the user for which you’d like to set an avatar, nickname, vcard…Await
Contact.add_to_roster()
in here to add the contact to the user’s XMPP roster.