From 737774b56c1694cd2b4cf8b03dd73bbeefe55b16 Mon Sep 17 00:00:00 2001 From: Jeremy Tuloup Date: Tue, 7 Jul 2020 14:35:21 +0200 Subject: [PATCH] Filter environments based on URL parameters --- tljh-plasma/tljh_plasma/__init__.py | 14 ++++++++++++++ 1 file changed, 14 insertions(+) diff --git a/tljh-plasma/tljh_plasma/__init__.py b/tljh-plasma/tljh_plasma/__init__.py index 2c179e1..c0df961 100644 --- a/tljh-plasma/tljh_plasma/__init__.py +++ b/tljh-plasma/tljh_plasma/__init__.py @@ -2,6 +2,8 @@ import os import pwd +from urllib.parse import urlparse, parse_qs + from dockerspawner import SystemUserSpawner from jupyterhub.auth import PAMAuthenticator from jupyterhub.handlers.static import CacheControlStaticFilesHandler @@ -29,6 +31,7 @@ class PlasmaSpawner(SpawnerMixin, SystemUserSpawner): ) async def list_images(self): + # filter images based on the group permissions all_images = await super().list_images() groups = [ group.gr_name for group in grp.getgrall() if self.user.name in group.gr_mem @@ -36,6 +39,17 @@ async def list_images(self): permissions = self.db.query(Permissions).filter(Permissions.group.in_(groups)) whitelist = set(p.image for p in permissions) images = [image for image in all_images if image["image_name"] in whitelist] + + # filter images based on the url query parameter + next_url = self.handler.get_argument("next", default="") + query = urlparse(next_url).query + parsed = parse_qs(query) + if "environment-name" in parsed: + display_name = parsed["environment-name"][0] + images = [ + image for image in images if image["display_name"] == display_name + ] + return images async def start(self, *args, **kwargs):