matteridge.contact

Module Contents

Classes

Contact

This class centralizes actions in relation to a specific legacy contact.

Roster

Virtual roster of a gateway user, that allows to represent all

Functions

noop()

async matteridge.contact.noop()[source]
class matteridge.contact.Contact(session, legacy_id, jid_username, user=None)[source]

Bases: matteridge.util.UserMixin, 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. The LegacyRoster instance of a session is accessible through the BaseSession.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 (matteridge.session.Session) – The session this contact is part of

  • legacy_id (str) – The contact’s legacy ID

  • jid_username (str) – User part of this contact’s ‘puppet’ JID. NB: case-insensitive, and some special characters are not allowed

  • user (Optional[mattermost_api_reference_client.models.User])

session: matteridge.session.Session[source]
STATUS_FETCH_MINIMUM_INTERVAL[source]
STATUS_API_FETCH_MINIMUM_INTERVAL[source]
MARKS = False[source]
REPLIES = False[source]
async on_friend_request(text='')[source]

Called when receiving a “subscribe” presence, ie, “I would like to add you to my contacts/friends”, from the user to this contact.

In XMPP terms: “I would like to receive your presence updates”

This is only called if self.is_friend = False. If self.is_friend = True, slidge will automatically “accept the friend request”, ie, reply with a “subscribed” presence.

When called, a ‘friend request event’ should be sent to the legacy service, and when the contact responds, you should either call self.accept_subscription() or self.reject_subscription()

update_websocket_status(status)[source]
Parameters:

status (matteridge.events.StatusType)

update_custom_status(c=None)[source]
Parameters:

c (Optional[mattermost_api_reference_client.models.UpdateUserCustomStatusJsonBody])

async fetch_ws_status()[source]
async fetch_api_status()[source]
async _reset_custom_status(sleep)[source]
Parameters:

sleep (float)

update_api_status(status)[source]
Parameters:

status (mattermost_api_reference_client.models.Status)

_update_presence()[source]
async direct_channel_id()[source]
async mm_id()[source]
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”.

To take advantage of the slidge avatar cache, you can check the .avatar property to retrieve the “legacy file ID” of the cached avatar. If there is no change, you should not call slidge.core.mixins.avatar.AvatarMixin.set_avatar() or attempt to modify the .avatar property.

Parameters:

user (Optional[mattermost_api_reference_client.models.User])

class matteridge.contact.Roster(session)[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 own LegacyRoster instance accessible via the BaseSession.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/or LegacyRoster.jid_username_to_legacy_id() to incorporate some custom logic if you need some characters when translation JID user parts and legacy IDs.

Parameters:

session (slidge.core.session.BaseSession)

property mm[source]
session: matteridge.session.Session[source]
STATUS_POLL_INTERVAL = 300[source]
async by_jid(jid)[source]
async by_legacy_id(legacy_id, user=None, *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

  • user (Optional[mattermost_api_reference_client.models.User])

Returns:

Return type:

Contact

async update_statuses()[source]
async by_mm_user_id(user_id, user=None)[source]
Parameters:
  • user_id (str)

  • user (Optional[mattermost_api_reference_client.models.User])

Return type:

Contact

async by_direct_channel_id(channel_id)[source]
Parameters:

channel_id (str)

Return type:

Optional[Contact]

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.

async known_user_ids(only_friends=False, including_me=True)[source]