123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104 |
- import re
- import cgi
- import copy
- from Plugin import PluginManager
- from Translate import Translate
- if "_" not in locals():
- _ = Translate("plugins/Cors/languages/")
- def getCorsPath(site, inner_path):
- match = re.match("^cors-([A-Za-z0-9]{26,35})/(.*)", inner_path)
- if not match:
- raise Exception("Invalid cors path: %s" % inner_path)
- cors_address = match.group(1)
- cors_inner_path = match.group(2)
- if not "Cors:%s" % cors_address in site.settings["permissions"]:
- raise Exception("This site has no permission to access site %s" % cors_address)
- return cors_address, cors_inner_path
- @PluginManager.registerTo("UiWebsocket")
- class UiWebsocketPlugin(object):
- def hasSitePermission(self, address, cmd=None):
- if super(UiWebsocketPlugin, self).hasSitePermission(address, cmd=cmd):
- return True
- if not "Cors:%s" % address in self.site.settings["permissions"] or cmd not in ["fileGet", "fileList", "dirList", "fileRules", "optionalFileInfo", "fileQuery", "dbQuery", "userGetSettings", "siteInfo"]:
- return False
- else:
- return True
- # Add cors support for file commands
- def corsFuncWrapper(self, func_name, to, inner_path, *args, **kwargs):
- if inner_path.startswith("cors-"):
- cors_address, cors_inner_path = getCorsPath(self.site, inner_path)
- req_self = copy.copy(self)
- req_self.site = self.server.sites.get(cors_address) # Change the site to the merged one
- if not req_self.site:
- return {"error": "No site found"}
- func = getattr(super(UiWebsocketPlugin, req_self), func_name)
- back = func(to, cors_inner_path, *args, **kwargs)
- return back
- else:
- func = getattr(super(UiWebsocketPlugin, self), func_name)
- return func(to, inner_path, *args, **kwargs)
- def actionFileGet(self, to, inner_path, *args, **kwargs):
- return self.corsFuncWrapper("actionFileGet", to, inner_path, *args, **kwargs)
- def actionFileList(self, to, inner_path, *args, **kwargs):
- return self.corsFuncWrapper("actionFileList", to, inner_path, *args, **kwargs)
- def actionDirList(self, to, inner_path, *args, **kwargs):
- return self.corsFuncWrapper("actionDirList", to, inner_path, *args, **kwargs)
- def actionFileRules(self, to, inner_path, *args, **kwargs):
- return self.corsFuncWrapper("actionFileRules", to, inner_path, *args, **kwargs)
- def actionOptionalFileInfo(self, to, inner_path, *args, **kwargs):
- return self.corsFuncWrapper("actionOptionalFileInfo", to, inner_path, *args, **kwargs)
- def actionCorsPermission(self, to, address):
- site = self.server.sites.get(address)
- if site:
- site_name = site.content_manager.contents.get("content.json", {}).get("title")
- button_title = _["Grant"]
- else:
- site_name = address
- button_title = _["Grant & Add"]
- if site and "Cors:" + address in self.permissions:
- return "ignored"
- self.cmd(
- "confirm",
- [_["This site requests <b>read</b> permission to: <b>%s</b>"] % cgi.escape(site_name), button_title],
- lambda (res): self.cbCorsPermission(to, address)
- )
- def cbCorsPermission(self, to, address):
- self.actionPermissionAdd(to, "Cors:" + address)
- site = self.server.sites.get(address)
- if not site:
- self.server.site_manager.need(address)
- @PluginManager.registerTo("UiRequest")
- class UiRequestPlugin(object):
- # Allow to load cross origin files using /cors-address/file.jpg
- def parsePath(self, path):
- path_parts = super(UiRequestPlugin, self).parsePath(path)
- if "cors-" not in path: # Optimization
- return path_parts
- site = self.server.sites[path_parts["address"]]
- try:
- path_parts["address"], path_parts["inner_path"] = getCorsPath(site, path_parts["inner_path"])
- except:
- return None
- return path_parts
|