Mercurial > libervia-backend
view libervia/backend/plugins/plugin_exp_invitation_file.py @ 4297:0f953ce5f0a8
core (xmpp): move `is_local` to `SatXMPPEntity` + type hints + some log level changes.
author | Goffi <goffi@goffi.org> |
---|---|
date | Fri, 06 Sep 2024 17:42:07 +0200 |
parents | 0d7bb4df2343 |
children |
line wrap: on
line source
#!/usr/bin/env python3 # SàT plugin to send invitations for file sharing # Copyright (C) 2009-2021 Jérôme Poisson (goffi@goffi.org) # This program is free software: you can redistribute it and/or modify # it under the terms of the GNU Affero General Public License as published by # the Free Software Foundation, either version 3 of the License, or # (at your option) any later version. # This program is distributed in the hope that it will be useful, # but WITHOUT ANY WARRANTY; without even the implied warranty of # MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the # GNU Affero General Public License for more details. # You should have received a copy of the GNU Affero General Public License # along with this program. If not, see <http://www.gnu.org/licenses/>. from libervia.backend.core.i18n import _ from libervia.backend.core.constants import Const as C from libervia.backend.core.log import getLogger from libervia.backend.core.xmpp import SatXMPPEntity from libervia.backend.tools.common import data_format from twisted.internet import defer from twisted.words.protocols.jabber import jid log = getLogger(__name__) PLUGIN_INFO = { C.PI_NAME: "File Sharing Invitation", C.PI_IMPORT_NAME: "FILE_SHARING_INVITATION", C.PI_TYPE: "EXP", C.PI_PROTOCOLS: [], C.PI_DEPENDENCIES: ["XEP-0329", "INVITATION"], C.PI_RECOMMENDATIONS: [], C.PI_MAIN: "FileSharingInvitation", C.PI_HANDLER: "no", C.PI_DESCRIPTION: _("Experimental handling of invitations for file sharing"), } class FileSharingInvitation: def __init__(self, host): log.info(_("File Sharing Invitation plugin initialization")) self.host = host ns_fis = host.get_namespace("fis") host.plugins["INVITATION"].register_namespace(ns_fis, self.on_invitation) host.bridge.add_method( "fis_invite", ".plugin", in_sign="ssssssss", out_sign="", method=self._send_file_sharing_invitation, async_=True, ) def _send_file_sharing_invitation( self, invitee_jid_s, service_s, repos_type=None, namespace=None, path=None, name=None, extra_s="", profile_key=C.PROF_KEY_NONE, ): client = self.host.get_client(profile_key) invitee_jid = jid.JID(invitee_jid_s) service = jid.JID(service_s) extra = data_format.deserialise(extra_s) return defer.ensureDeferred( self.host.plugins["INVITATION"].send_file_sharing_invitation( client, invitee_jid, service, repos_type=repos_type or None, namespace=namespace or None, path=path or None, name=name or None, extra=extra, ) ) def on_invitation( self, client: SatXMPPEntity, namespace: str, name: str, extra: dict, service: jid.JID, repos_type: str, sharing_ns: str, path: str, ): if repos_type == "files": type_human = _("file sharing") elif repos_type == "photos": type_human = _("photo album") else: log.warning( "Unknown repository type: {repos_type}".format(repos_type=repos_type) ) repos_type = "file" type_human = _("file sharing") log.info( _( "{profile} has received an invitation for a files repository ({type_human}) " "with namespace {sharing_ns!r} at path [{path}]" ).format( profile=client.profile, type_human=type_human, sharing_ns=sharing_ns, path=path, ) ) return defer.ensureDeferred( self.host.plugins["LIST_INTEREST"].register_file_sharing( client, service, repos_type, sharing_ns, path, name, extra ) )