From 68563386edf2be1b0f45ce4d0b587204d8f6ad6b Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Andrey=20Ca=C3=B1on?= Date: Thu, 3 Oct 2019 11:52:57 -0500 Subject: [PATCH] PE-541 Improve performance (#72) * Store response in cache and get teams objects from the model instead of use the api * Remove unnecessary spaces --- rocketc/rocketc.py | 47 +++++++++++++++++++++----------- rocketc/static/html/rocketc.html | 4 +-- 2 files changed, 33 insertions(+), 18 deletions(-) diff --git a/rocketc/rocketc.py b/rocketc/rocketc.py index b02d1cc4..785bf261 100644 --- a/rocketc/rocketc.py +++ b/rocketc/rocketc.py @@ -10,6 +10,7 @@ from api_teams import ApiTeams # pylint: disable=relative-import from api_rocket_chat import ApiRocketChat # pylint: disable=relative-import +from lms.djangoapps.teams.models import CourseTeamMembership from django.conf import settings from django.contrib.auth.models import User from django.utils.translation import ugettext_lazy as _ @@ -56,9 +57,9 @@ def generate_query_dict(course, team=None, specific_team=False): def generate_team_variables(team): - if isinstance(team, dict): - topic_id = re.sub(r'\W+', '', team.get("topic_id", None)) - team_name = re.sub(r'\W+', '', team.get("name", None)) + if team: + topic_id = re.sub(r'\W+', '', team.topic_id) + team_name = re.sub(r'\W+', '', team.name) return team_name, topic_id return None, None @@ -206,7 +207,6 @@ def student_view(self, context=None): "response": self.init(), "user_data": self.user_data, "ui_is_block": self.ui_is_block, - "team_view": self.team_view, "public_url_service": self.server_data["public_url_service"], "key": hashlib.sha1("{}_{}".format(ROCKET_CHAT_DATA, self.user_data["username"])).hexdigest() } @@ -383,17 +383,28 @@ def init(self): """ user_data = self.user_data + key = hashlib.sha1("{}-{}-{}-{}-{}".format( + ROCKET_CHAT_DATA, + user_data["username"], + self.selected_view, + self.default_channel, + self._get_team(user_data["username"]), + )).hexdigest() + response = cache.get(key) + + if response: + return response response = self._login(user_data) if response['success']: response = response['data'] user_id = response['userId'] auth_token = response['authToken'] - response['default_group'] = self._join_user_to_groups(user_id, user_data, auth_token) + response['team_view'] = self.team_view self._update_user(user_id, user_data) - self._grading_discussions(response['default_group']) + cache.set(key, response, CACHE_TIMEOUT) return response return response['errorType'] @@ -403,17 +414,18 @@ def _login(self, user_data): This method allows to get the user's authToken and id or creates a user to login in RocketChat """ - api = self.api_rocket_chat - - rocket_chat_user = api.search_rocket_chat_user(user_data["username"]) - LOG.info("Login method: result search user: %s", rocket_chat_user["success"]) - key = hashlib.sha1("{}_{}".format(ROCKET_CHAT_DATA, user_data["username"])).hexdigest() data = cache.get(key) if data: return data - elif rocket_chat_user['success']: + + api = self.api_rocket_chat + + rocket_chat_user = api.search_rocket_chat_user(user_data["username"]) + LOG.info("Login method: result search user: %s", rocket_chat_user["success"]) + + if rocket_chat_user["success"]: data = api.create_token(user_data["username"]) else: response = api.create_user(user_data["anonymous_student_id"], user_data[ @@ -476,10 +488,13 @@ def _get_team(self, username): """ This method gets the user's team """ - team = self.api_teams.get_user_team(self.runtime.course_id, username) - LOG.info("Get Team response: %s", team) - if team: - return team[0] + course_team_membership = CourseTeamMembership.objects.filter( + user=User.objects.get(username=username), + ) + + if course_team_membership: + return course_team_membership[0].team + return None def _join_user_to_groups(self, user_id, user_data, auth_token): diff --git a/rocketc/static/html/rocketc.html b/rocketc/static/html/rocketc.html index 9b5de460..be798995 100755 --- a/rocketc/static/html/rocketc.html +++ b/rocketc/static/html/rocketc.html @@ -2,7 +2,7 @@ {% url 'teams_dashboard' user_data.course_id as teams_page%} {% url 'support:contact_us' as support %}
- {% if ui_is_block and team_view %} + {% if ui_is_block and response.team_view %} {% if "authToken" in response %}
@@ -45,7 +45,7 @@ {{response}} {% endif %} - {% elif not team_view %} + {% elif not response.team_view %}