Mercurial > libervia-backend
diff libervia/backend/plugins/plugin_xep_0048.py @ 4327:554a87ae17a6
plugin XEP-0048, XEP-0402; CLI (bookmarks): implement XEP-0402 (PEP Native Bookmarks):
- Former bookmarks implementation is now labeled as "legacy".
- XEP-0402 is now used for bookmarks when relevant namespaces are found, and it fallbacks
to legacy XEP-0048/XEP-0049 bookmarks otherwise.
- CLI legacy bookmark commands have been moved to `bookmarks legacy`
- CLI bookmarks commands now use the new XEP-0402 (with fallback to legacy one
automatically used if necessary).
author | Goffi <goffi@goffi.org> |
---|---|
date | Wed, 20 Nov 2024 11:43:27 +0100 |
parents | 0d7bb4df2343 |
children | 111dce64dcb5 |
line wrap: on
line diff
--- a/libervia/backend/plugins/plugin_xep_0048.py Wed Nov 20 11:38:44 2024 +0100 +++ b/libervia/backend/plugins/plugin_xep_0048.py Wed Nov 20 11:43:27 2024 +0100 @@ -1,8 +1,8 @@ #!/usr/bin/env python3 -# SAT plugin for Bookmarks (xep-0048) -# Copyright (C) 2009-2021 Jérôme Poisson (goffi@goffi.org) +# Libervia plugin for Bookmarks (xep-0048) +# Copyright (C) 2009-2024 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 @@ -71,28 +71,30 @@ self.__selected_id = host.register_callback( self._bookmark_selected_cb, with_data=True ) + # XXX: We're transitionning to XEP-0402, so we mark bridge method as "legacy" + # here. host.bridge.add_method( - "bookmarks_list", + "bookmarks_legacy_list", ".plugin", in_sign="sss", out_sign="a{sa{sa{ss}}}", - method=self._bookmarks_list, + method=self.bookmarks_list, async_=True, ) host.bridge.add_method( - "bookmarks_remove", + "bookmarks_legacy_remove", ".plugin", in_sign="ssss", out_sign="", - method=self._bookmarks_remove, + method=self.bookmarks_remove, async_=True, ) host.bridge.add_method( - "bookmarks_add", + "bookmarks_legacy_add", ".plugin", in_sign="ssa{ss}ss", out_sign="", - method=self._bookmarks_add, + method=self.bookmarks_add, async_=True, ) try: @@ -419,7 +421,12 @@ if storage_type == "pubsub": raise NotImplementedError - def _bookmarks_list(self, type_, storage_location, profile_key=C.PROF_KEY_NONE): + def bookmarks_list( + self, + type_: str, + storage_location: str, + profile_key: str = C.PROF_KEY_NONE + ) -> defer.Deferred[dict]: """Return stored bookmarks @param type_: bookmark type, one of: @@ -458,7 +465,8 @@ if storage_location in ("all", _storage_location): ret[_storage_location] = {} if _storage_location in ("private",): - # we update distant bookmarks, just in case an other client added something + # we update distant bookmarks, just in case an other client added + # something d = self._get_server_bookmarks(_storage_location, client.profile) else: d = defer.succeed(None) @@ -467,7 +475,7 @@ return ret_d - def _bookmarks_remove( + def bookmarks_remove( self, type_, location, storage_location, profile_key=C.PROF_KEY_NONE ): """Return stored bookmarks @@ -487,7 +495,7 @@ location = jid.JID(location) return self.remove_bookmark(type_, location, storage_location, profile_key) - def _bookmarks_add( + def bookmarks_add( self, type_, location, data, storage_type="auto", profile_key=C.PROF_KEY_NONE ): if type_ == XEP_0048.MUC_TYPE: