Commit d5a77dd7 by Harry Rein

Don't show unpulished or un-upgradable seats in available sessions.

parent 72bb440d
...@@ -3,7 +3,6 @@ Student Views ...@@ -3,7 +3,6 @@ Student Views
""" """
import datetime import datetime
import dateutil
import json import json
import logging import logging
import uuid import uuid
...@@ -75,7 +74,7 @@ from lms.djangoapps.verify_student.models import SoftwareSecurePhotoVerification ...@@ -75,7 +74,7 @@ from lms.djangoapps.verify_student.models import SoftwareSecurePhotoVerification
# Note that this lives in LMS, so this dependency should be refactored. # Note that this lives in LMS, so this dependency should be refactored.
from notification_prefs.views import enable_notifications from notification_prefs.views import enable_notifications
from openedx.core.djangoapps import monitoring_utils from openedx.core.djangoapps import monitoring_utils
from openedx.core.djangoapps.catalog.utils import get_programs_with_type, get_course_runs_for_course from openedx.core.djangoapps.catalog.utils import get_programs_with_type, get_visible_course_runs_for_course
from openedx.core.djangoapps.certificates.api import certificates_viewable_for_course from openedx.core.djangoapps.certificates.api import certificates_viewable_for_course
from openedx.core.djangoapps.credit.email_utils import get_credit_provider_display_names, make_providers_strings from openedx.core.djangoapps.credit.email_utils import get_credit_provider_display_names, make_providers_strings
from openedx.core.djangoapps.embargo import api as embargo_api from openedx.core.djangoapps.embargo import api as embargo_api
...@@ -703,16 +702,10 @@ def dashboard(request): ...@@ -703,16 +702,10 @@ def dashboard(request):
course_entitlement_available_sessions = {} course_entitlement_available_sessions = {}
for course_entitlement in course_entitlements: for course_entitlement in course_entitlements:
course_entitlement.update_expired_at() course_entitlement.update_expired_at()
# Filter only the course runs that do not have an enrollment_end date set, or have one set in the future valid_course_runs = get_visible_course_runs_for_course(
course_runs_for_course = get_course_runs_for_course(str(course_entitlement.course_uuid)) course_entitlement, str(course_entitlement.course_uuid)
enrollable_course_runs = [] )
course_entitlement_available_sessions[str(course_entitlement.uuid)] = valid_course_runs
for course_run in course_runs_for_course:
enrollment_end = course_run.get('enrollment_end')
if not enrollment_end or (dateutil.parser.parse(enrollment_end) > datetime.datetime.now(UTC)):
enrollable_course_runs.append(course_run)
course_entitlement_available_sessions[str(course_entitlement.uuid)] = enrollable_course_runs
# Record how many courses there are so that we can get a better # Record how many courses there are so that we can get a better
# understanding of usage patterns on prod. # understanding of usage patterns on prod.
......
"""Helper functions for working with the catalog service.""" """Helper functions for working with the catalog service."""
from dateutil.parser import parse as datetime_parse
import copy import copy
import datetime
import logging import logging
from django.conf import settings from django.conf import settings
...@@ -14,6 +16,7 @@ from openedx.core.djangoapps.catalog.cache import ( ...@@ -14,6 +16,7 @@ from openedx.core.djangoapps.catalog.cache import (
from openedx.core.djangoapps.catalog.models import CatalogIntegration from openedx.core.djangoapps.catalog.models import CatalogIntegration
from openedx.core.lib.edx_api_utils import get_edx_api_data from openedx.core.lib.edx_api_utils import get_edx_api_data
from openedx.core.lib.token_utils import JwtBuilder from openedx.core.lib.token_utils import JwtBuilder
from pytz import UTC
logger = logging.getLogger(__name__) logger = logging.getLogger(__name__)
...@@ -239,6 +242,47 @@ def get_course_runs_for_course(course_uuid): ...@@ -239,6 +242,47 @@ def get_course_runs_for_course(course_uuid):
else: else:
return [] return []
def get_visible_course_runs_for_course(entitlement, course_uuid):
"""
We only want to show courses for a particular entitlement that:
1) Are currently running or in the future
2) A user can enroll in
3) A user can upgrade in
4) Are published
"""
course_runs_for_course = get_course_runs_for_course(course_uuid)
enrollable_course_runs = []
# Only show published course runs that can still be enrolled and upgraded
now = datetime.datetime.now(UTC)
for course_run in course_runs_for_course:
# Only courses that have not ended will be displayed
run_start = course_run.get('start')
run_end = course_run.get('end')
is_running = run_start and run_end and datetime_parse(run_end) > now
# Only courses that can currently be enrolled in will be displayed
enrollment_start = course_run.get('enrollment_start')
enrollment_end = course_run.get('enrollment_end')
can_enroll = ((not enrollment_start or datetime_parse(enrollment_start) < now)
and (not enrollment_end or (datetime_parse(enrollment_end) > now)))
# Only upgrade-able courses will be displayed
upgrade_deadline = next(iter(
[seat.get('upgrade_deadline') for seat in course_run.get('seats')
if seat.get('type') == entitlement.mode]), None
)
can_upgrade = not upgrade_deadline or (datetime_parse(upgrade_deadline) > now)
# Only published courses will be displayed
is_published = course_run.get('status') == 'published'
if is_running and can_upgrade and can_enroll and is_published:
enrollable_course_runs.append(course_run)
return enrollable_course_runs
def get_course_run_details(course_run_key, fields): def get_course_run_details(course_run_key, fields):
""" """
......
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment