Mercurial > libervia-web
view libervia/server/restricted_bridge.py @ 1374:25104d31479f
pages: `on_data_post` can now return `"continue"` string:
if "continue" is returned, the page workflow is not interrupted with Post/Redirect/Get
pattern.
author | Goffi <goffi@goffi.org> |
---|---|
date | Fri, 11 Dec 2020 17:35:03 +0100 |
parents | a32f3f47e4a8 |
children | 4c51f22a813a |
line wrap: on
line source
#!/usr/bin/env python3 # Libervia: a SàT frontend # Copyright (C) 2009-2020 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.server.constants import Const as C from sat.tools.common import data_format class RestrictedBridge: """Bridge with limited access, which can be used in browser Only a few method are implemented, with potentially dangerous argument controlled. Security limit is used """ def __init__(self, host): self.host = host self.security_limit = C.SECURITY_LIMIT async def getContacts(self, profile): return await self.host.bridgeCall("getContacts", profile) async def identityGet(self, entity, metadata_filter, use_cache, profile): return await self.host.bridgeCall( "identityGet", entity, metadata_filter, use_cache, profile) async def identitiesGet(self, entities, metadata_filter, profile): return await self.host.bridgeCall( "identitiesGet", entities, metadata_filter, profile) async def identitiesBaseGet(self, profile): return await self.host.bridgeCall( "identitiesBaseGet", profile) async def fileHTTPUploadGetSlot( self, filename, size, content_type, upload_jid, profile): return await self.host.bridgeCall( "fileHTTPUploadGetSlot", filename, size, content_type, upload_jid, profile) async def fileSharingDelete( self, service_jid, path, namespace, profile): return await self.host.bridgeCall( "fileSharingDelete", service_jid, path, namespace, profile) async def interestsRegisterFileSharing( self, service, repos_type, namespace, path, name, extra_s, profile ): if extra_s: # we only allow "thumb_url" here extra = data_format.deserialise(extra_s) if "thumb_url" in extra: extra_s = data_format.serialise({"thumb_url": extra["thumb_url"]}) else: extra_s = "" return await self.host.bridgeCall( "interestsRegisterFileSharing", service, repos_type, namespace, path, name, extra_s, profile ) async def interestRetract( self, service_jid, item_id, profile ): return await self.host.bridgeCall( "interestRetract", service_jid, item_id, profile) async def FISInvite( self, invitee_jid_s, service_s, repos_type, namespace, path, name, extra_s, profile ): if extra_s: # we only allow "thumb_url" here extra = data_format.deserialise(extra_s) if "thumb_url" in extra: extra_s = data_format.serialise({"thumb_url": extra["thumb_url"]}) else: extra_s = "" return await self.host.bridgeCall( "FISInvite", invitee_jid_s, service_s, repos_type, namespace, path, name, extra_s, profile ) async def FISAffiliationsSet( self, service_s, namespace, path, affiliations, profile ): return await self.host.bridgeCall( "FISAffiliationsSet", service_s, namespace, path, affiliations, profile ) async def invitationSimpleCreate( self, invitee_email, invitee_name, url_template, extra_s, profile ): return await self.host.bridgeCall( "invitationSimpleCreate", invitee_email, invitee_name, url_template, extra_s, profile )